1Mybatis常见面试题(转)1、#{}和${}的区别是什么
注:这道题是面试官面试我同事的
答:${}是Properties文件中的变量占位符,它可以用于标签属性值和sql内部,属于静态文本替换,比如${driver}会被静态替换为com
Driver
#{}是sql的参数占位符,Mybatis会将sql中的#{}替换为
号,在sql执行前会使用PreparedStatement的参数设置方法,按序给sql的
号占位符设置参数值,比如ps
setInt(0,parameterValue),#{item
name}的取值方式为使用反射从参数对象中获取item对象的name属性值,相当于param
getItem()
getName()
2、Xml映射文件中,除了常见的select|insert|updae|delete标签之外,还有哪些标签
注:这道题是京东面试官面试我时问的
答:还有很多其他的标签,、、、、,加上动态sql的9个标签,trim|where|set|foreach|if|choose|when|otherwise|bind等,其中为sql片段标签,通过标签引入sql片段,为不支持自增的主键生成策略标签
3、最佳实践中,通常一个Xml映射文件,都会写一个Dao接口与之对应,请问,这个Dao接口的工作原理是什么
Dao接口里的方法,参数不同时,方法能重载吗
注:这道题也是京东面试官面试我时问的
答:Dao接口,就是人们常说的Mapper接口,接口的全限名,就是映射文件中的namespace的值,接口的方法名,就是映射文件中MappedStatement的id值,接口方法内的参数,就是传递给sql的参数
Mapper接口是没有实现类的,当调用接口方法时,接口全限名+方法名拼接字符串作为key值,可唯一定位一个MappedStatement,