当前位置: 首页 > news >正文

架构师面试题系列之Mybatis面试专题及答案(36题)

目录

  • 1、什么是 MyBatis?
  • 2、讲下 MyBatis 的缓存
  • 3、Mybatis 是如何进行分页的?分页插件的原理是什么?
  • 4、简述 Mybatis 的插件运行原理,以及如何编写一个插件?
  • 5、Mybatis 动态 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、当实体类中的属性名和表中的字段名不一样,如果将查询的结
  • 21、模糊查询 like 语句该怎么写
  • 22、通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应,
  • 23、Mybatis 映射文件中,如果 A 标签通过 include 引用了 B
  • 24、Mybatis 的 Xml 映射文件中,不同的 Xml 映射文件,id 是
  • 25、Mybatis 中如何执⾏批处理?
  • 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 注⼊,提⾼系统安全性。

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

别在哪里?
答:Hibernate 属于全⾃动 ORM 映射⼯具,使⽤ Hibernate 查询关联对象或
者关联集合对象时,可以根据对象关系模型直接获取,所以它是全⾃动的。⽽
Mybatis 在查询关联对象或关联集合对象时,需要⼿动编写 sql 来完成,所
以,称之为半⾃动 ORM 映射⼯具。

8、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()⽅法的调⽤。这就是延迟加载的基本原理。

9、MyBatis 与 Hibernate 有哪些不同?

答:
1&#x

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • OZON电子类目解封,OZON新品飙升榜
  • pgsql导入导出数据
  • (1)Hilt的基本概念和使用
  • 【pip】【conda】使用 `pip` 和 `conda` 生成 `requirements.txt` 文件的指南
  • 【网络安全】分析cookie实现PII IDOR
  • 人工智能与神经科学:理解大脑的新维度
  • Windows Edge浏览器的兼容性问题
  • 原型图和UI的区别与联系
  • [Java]SpringBoot快速入门
  • strlen函数模拟实现——深入理解指针(3)
  • 基于x86 平台opencv的图像采集和seetaface6的眼睛状态检测(睁眼,闭眼)功能
  • Linux开发环境搭建,虚拟机安装
  • Linux安装使用Apache(Windows下载,离线安装)
  • 构建第一个zk
  • MVSEP-MDX23容器构建详细教程
  • 《Java8实战》-第四章读书笔记(引入流Stream)
  • 「前端早读君006」移动开发必备:那些玩转H5的小技巧
  • 【跃迁之路】【733天】程序员高效学习方法论探索系列(实验阶段490-2019.2.23)...
  • ES6之路之模块详解
  • miaov-React 最佳入门
  • Python中eval与exec的使用及区别
  • 对JS继承的一点思考
  • 仿天猫超市收藏抛物线动画工具库
  • 给github项目添加CI badge
  • 前端知识点整理(待续)
  • 区块链共识机制优缺点对比都是什么
  • 微信小程序开发问题汇总
  • 详解移动APP与web APP的区别
  • 一份游戏开发学习路线
  • 再谈express与koa的对比
  • 在GitHub多个账号上使用不同的SSH的配置方法
  • 仓管云——企业云erp功能有哪些?
  • 移动端高清、多屏适配方案
  • 支付宝花15年解决的这个问题,顶得上做出十个支付宝 ...
  • ​LeetCode解法汇总2670. 找出不同元素数目差数组
  • # Swust 12th acm 邀请赛# [ E ] 01 String [题解]
  • #include<初见C语言之指针(5)>
  • %@ page import=%的用法
  • (11)MATLAB PCA+SVM 人脸识别
  • (笔试题)合法字符串
  • (理论篇)httpmoudle和httphandler一览
  • (区间dp) (经典例题) 石子合并
  • (四)React组件、useState、组件样式
  • (一)基于IDEA的JAVA基础10
  • (一)项目实践-利用Appdesigner制作目标跟踪仿真软件
  • (转)Mysql的优化设置
  • (转)shell中括号的特殊用法 linux if多条件判断
  • ***原理与防范
  • .Net 8.0 新的变化
  • .net core IResultFilter 的 OnResultExecuted和OnResultExecuting的区别
  • .NET WebClient 类下载部分文件会错误?可能是解压缩的锅
  • .NET 的程序集加载上下文
  • .NET 项目中发送电子邮件异步处理和错误机制的解决方案
  • .NET/C# 编译期间能确定的相同字符串,在运行期间是相同的实例
  • .NETCORE 开发登录接口MFA谷歌多因子身份验证