大厂必问Mybatis面试专题,架构师宝典

1、什么是 MyBatis?

2、讲下 MyBatis 的缓存

3、Mybatis 是如何进行分页的?分页插件的原理是什么?

4、简述 Mybatis 的插件运行原理,以及如何编写一个插件?

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

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

7、为什么说 Mybatis 是半自动 ORM 映射工具?它与全自动的区别在哪里?

8、Mybatis 是否支持延迟加载?如果支持,它的实现原理是什么?

9、MyBatis 与 Hibernate 有哪些不同?

10、MyBatis 的好处是什么?

11、简述 Mybatis 的 Xml 映射文件和 Mybatis 内部数据结构之间的映射关系?

12、什么是 MyBatis 的接口绑定,有什么好处?

13、接口绑定有几种实现方式,分别是怎么实现的?

14、什么情况下用注解绑定,什么情况下用 xml 绑定?

15、MyBatis 实现一对一有几种方式?具体怎么操作的?

16、Mybatis 能执行一对一、一对多的关联查询吗?都有哪些实现方式,以及它们之间的区别?

17、MyBatis 里面的动态 Sql 是怎么设定的?用什么语法?

18、Mybatis 是如何将 sql 执行结果封装为目标对象并返回的?都有哪些映射形式?

19、Xml 映射文件中,除了常见的 select|insert|updae|delete 标签之外,还有哪些标签?

20、当实体类中的属性名和表中的字段名不一样,如果将查询的结果封装到指定 pojo?

21、模糊查询 like 语句该怎么写

22、通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应, Dao 的工作原理,是否可以重载?

23、Mybatis 映射文件中,如果 A 标签通过 include 引用了 B 标签的内容,请问,B 标签能否定义在 A 标签的后面,还是说必须定义在 A 标签的前面?

24、Mybatis 的 Xml 映射文件中,不同的 Xml 映射文件,id 是否可以重复?

26、Mybatis 都有哪些 Executor 执行器?它们之间的区别是什么?

27、Mybatis 中如何指定使用哪一种 Executor 执行器?

28、Mybatis 执行批量插入,能返回数据库主键列表吗?

29、Mybatis 是否可以映射 Enum 枚举类?

30、如何获取自动生成的(主)键值?

31、在 mapper 中如何传递多个参数?

32、resultType resultMap 的区别?

33、使用 MyBatis 的 mapper 接口调用时有哪些要求?

34、Mybatis 比 IBatis 比较大的几个改进是什么?

35、IBatis 和 MyBatis 在核心处理类分别叫什么?

36、IBatis 和 MyBatis 在细节上的不同有哪些?



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 种接口对象的方法时,就会进入拦截方法,具体就是InvocationHandler 的 invoke()方法,当然,只会拦截那些你指定需要拦截的方法。

2)实现 Mybatis 的 Interceptor 接口并复写 intercept()方法,然后在给插件编写注解,指定要拦截哪一个接口的哪些方法即可,记住,别忘了在配置文件中配置你编写的插件。

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

答:

1)Mybatis 动态 sql 可以让我们在 Xml 映射文件内,以标签的形式编写动态 sql,完成逻辑判断和动态拼接 sql 的功能。

2)Mybatis 提供了 9 种动态 sql 标签:trim|where|set|foreach|if|choose|when|otherwise|bind。

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

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

答:

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

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

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

4)使用#{}可以有效的防止 SQL 注入,提高系统安全性。
...................................................................................................
#java##面试##面经##后端##架构师#
全部评论
这么多面试题库,感谢楼主的分享
点赞 回复 分享
发布于 2022-08-08 11:39

相关推荐

06-27 12:54
已编辑
门头沟学院 Java
累了,讲讲我的大学经历吧,目前在家待业。我是一个二本院校软件工程专业。最开始选专业是觉得计算机感兴趣,所以选择了他。本人学习计算机是从大二暑假结束开始的,也就是大三开始。当时每天学习,我个人认为Java以及是我生活的一部分了,就这样持续学习了一年半,来到了大四上学期末,大概是在12月中旬,我终于找的到了一家上海中厂的实习,但我发现实习生的工作很枯燥,公司分配的活也不多,大多时间也是自己在自学。就这样我秋招末才找到实习。时间来到了3月中旬,公司说我可以转正,但是转正工资只有7000,不过很稳定,不加班,双休,因为要回学校参加答辩了,同时当时也是心高气傲,认为可以找到更好的,所以放弃了转正机会,回学校准备论文。准备论文期间就也没有投递简历。然后时间来到了5月中旬,这时春招基本也结束了,然后我开始投递简历,期间只是约到了几家下场面试。工资也只有6-7k,到现在我不知道该怎么办了。已经没有当初学习的心劲了,好累呀,但是又不知道该干什么去。在家就是打游戏,boss简历投一投。每天日重一次。26秋招都说是针对26届的人,25怎么办。我好绝望。要不要参加考公、考研、央国企这些的。有没有大佬可以帮帮我。为什么感觉别人找工作都是顺其自然的事情,我感觉自己每一步都在艰难追赶。八股文背了又忘背了又忘,我每次都花很长时间去理解他,可是现在感觉八股、项目都忘完了。真的已经没有力气再去学习了。图片是我的简历,有没有大哥可以指正一下,或者说我应该走哪条路,有点不想在找工作了。
码客明:太累了就休息一下兄弟,人生不会完蛋的
如果实习可以转正,你会不...
点赞 评论 收藏
分享
求offer的大角牛:简历写的第一乱,没有突出重点,第二项目太多太杂看不出来有啥核心技术,第三自我评价太多了,第四获得的荣誉没啥含金量,可以不写,反正问题不少
点赞 评论 收藏
分享
评论
2
10
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务