1、什么是 MyBatis?
答: MyBatis 是一个可以自定义 SQL、存储过程和高级映射的持久层框架。
2、讲下 MyBatis 的缓存
答: MyBatis 的缓存分为一级缓存和二级缓存,一级缓存放在 session 里面,默认就有,二级缓存
放在它的命名空间里,默认是不打开的,使用二级缓存属性类需要实现 Serializable 序列化接口
(可用来保存对象的状态),可在它的映射文件中配置<cache/>
3、 Mybatis 是如何进行分页的?分页插件的原理是什么?
答:
1)Mybatis 使用 RowBounds 对象进行分页,也可以直接编写 sql 实现分页,也可以使用 Mybatis
的分页插件。
2)分页插件的原理:实现 Mybatis 提供的接口,实现自定义插件,在插件的拦截方法内拦
截待执行的 sql,然后重写 sql。
举例: select * from student,拦截 sql 后重写为: select t.* from (select * from student) t limit
0, 10
4、简述 Mybatis 的插件运行原理,以及如何编写一个插件?
答:
1) Mybatis 仅可以编写针对 ParameterHandler、 ResultSetHandler、 StatementHandler、 Executor
这 4 种接口的插件, Mybatis 通过动态代理,为需要拦截的接口生成代理对象以实现接口方
法拦截功能,每当执行这 4 种接口对象的方法时,就会进入拦截方法,具
06-06
1398
06-27
263
“相关推荐”对你有帮助么?
-
非常没帮助
-
没帮助
-
一般
-
有帮助
-
非常有帮助
提交