Mybatis常见面试题[2]

1、#{}和${}的区别是什么?
答:${}是Properties文件中的变量占位符,它可以用于标签属性值和sql内部,属于静
态文本替换,比如${driver}会被静态替换为com.mysql.jdbc.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,举例:com.mybatis3.mappers.StudentDao.findStudentById,
可以唯一找到namespace为com.mybatis3.mappers.StudentDao下面id = 
findStudentById的MappedStatement。在Mybatis中,每一个标签均会被解析为MappedStatement对象,标签内的sql会被解
析为BoundSql对象。
18、为什么说Mybatis是半自动ORM映射工具?它与全自动的区别在哪里?
答:Hibernate属于全自动ORM映射工具,使用Hibernate查询关联对象或者关联集合
对象时,可以根据对象关系模型直接获取,所以它是全自动的。而Mybatis在查询关
联对象或关联集合对象时,需要手动编写sql来完成,所以,称之为半自动ORM映射
工具。

转载自:@公众号 - JAVA小咖秀 - Mybatis 十八连环问!

Mybatis常见面试题[2]_第2张图片
JAVA小咖秀

你可能感兴趣的:(Mybatis常见面试题[2])