#Java面试-2018年MyBatis常见实用面试题2

1、Mybatis动态sql是做什么的?都有哪些动态sql?能简述一下动态sql的执行原理不?

答:

1)Mybatis动态sql可以让我们在Xml映射文件内,以标签的形式编写动态sql,完成逻辑判断和动态拼接sql的功能。
如果有想要学习java的小伙伴,可来我们的java学习扣裙哦:72340,3928里面赠送java系列教学视频和资料!小编也是从事了6年java开发的全栈工程师,欢迎初学者和想要进阶的同学进来一起学习。
在这里插入图片描述
2)Mybatis提供了9种动态sql标签:trim|where|set|foreach|if|choose|when|otherwise|bind。

3)其执行原理为,使用OGNL从sql参数对象中计算表达式的值,根据表达式的值动态拼接sql,以此来完成动态sql的功能。

2、#{}和${}的区别是什么?

答:

1)#{}是预编译处理,${}是字符串替换。

2)Mybatis在处理#{}时,会将sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值;

3)Mybatis在处理 {}时,就是把 {}替换成变量的值。

4)使用#{}可以有效的防止SQL注入,提高系统安全性。
在这里插入图片描述
3、为什么说Mybatis是半自动ORM映射工具?它与全自动的区别在哪里?

答:Hibernate属于全自动ORM映射工具,使用Hibernate查询关联对象或者关联集合对象时,可以根据对象关系模型直接获取,所以它是全自动的。而Mybatis在查询关联对象或关联集合对象时,需要手动编写sql来完成,所以,称之为半自动ORM映射工具。
在这里插入图片描述
4、Mybatis是否支持延迟加载?如果支持,它的实现原理是什么?

答:

1)Mybatis仅支持association关联对象和collection关联集合对象的延迟加载,association指的就是一对一,collection指的就是一对多查询。在Mybatis配置文件中,可以配置是否启用延迟加载lazyLoadingEnabled=true|false。

2)它的原理是,使用CGLIB创建目标对象的代理对象,当调用目标方法时,进入拦截器方法,比如调用a.getB().getName(),拦截器invoke()方法发现a.getB()是null值,那么就会单独发送事先保存好的查询关联B对象的sql,把B查询上来,然后调用a.setB(b),于是a的对象b属性就有值了,接着完成a.getB().getName()方法的调用。这就是延迟加载的基本原理。

猜你喜欢

转载自blog.csdn.net/javam16/article/details/82791866