MyBatis

目录

什么是 MyBatis?

 讲下 MyBatis 的缓存

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

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

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

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

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

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

MyBatis 与 Hibernate 有哪些不同?

MyBatis 的好处是什么?

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

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

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

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

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

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

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

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

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

模糊查询 like 语句该怎么写

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

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

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

Mybatis 中如何执行批处理?

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

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

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

resultType resultMap 的区别?

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

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

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

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


什么是 MyBatis?

MyBatis 是一个可以自定义 SQL 、存储过程和高级映射的持久层框架。

 讲下 MyBatis 的缓存

MyBatis 的缓存分为一级缓存和二级缓存 , 一级缓存放在 session 里面 , 默认就有 , 二级缓
存放在它的命名空间里 , 默认是不打开的 , 使用二级缓存属性类需要实现 Serializable 序列化
接口 ( 可用来保存对象的状态 ), 可在它的映射文件中配置 <cache/>

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

1 Mybatis 使用 RowBounds 对象进行分页,也可以直接编写 sql 实现分页,也可以使用
Mybatis 的分页插件。
2 )分页插件的原理:实现 Mybatis 提供的接口,实现自定义插件,在插件的拦截方法内拦
截待执行的 sql ,然后重写 sql
举例: select * from student ,拦截 sql 后重写为: select t.* from select * from student t
limit 0 10

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

1 Mybatis 仅可以编写针对 ParameterHandler ResultSetHandler StatementHandler
Executor 4 种接口的插件, Mybatis 通过动态代理,为需要拦截的接口生成代理对象以实现接口方法拦截功能,每当执行这 4 种接口对象的方法时,就会进入拦截方法,具体就是 InvocationHandler 的 invoke() 方法,当然,只会拦截那些你指定需要拦截的方法。
2 )实现 Mybatis Interceptor 接口并复写 intercept() 方法,然后在给插件编写注解,指定
要拦截哪一个接口的哪些方法即可,记住,别忘了在配置文件中配置你编写的插件。

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 的功能。

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

1 #{} 是预编译处理, ${} 是字符串替换。
2 Mybatis 在处理 #{} 时,会将 sql 中的 #{} 替换为 ? 号,调用 PreparedStatement set 方法来赋值;
3 Mybatis 在处理 ${} 时,就是把 ${} 替换成变量的值。
4 )使用 #{} 可以有效的防止 SQL 注入,提高系统安全性。

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

Hibernate 属于全自动 ORM 映射工具,使用 Hibernate 查询关联对象或者关联集合对象
时,可以根据对象关系模型直接获取,所以它是全自动的。而 Mybatis 在查询关联对象或
关联集合对象时,需要手动编写 sql 来完成,所以,称之为半自动 ORM 映射工具。

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(
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值