Mybatis
- 125.mybatis 中 #{}和 ${}的区别是什么?
#{} 占位符 即sql 预编译 对应的变量自动加上单引号 '' 能防止sql 注入
${} 拼接符 即 sql 拼接 对应的变量不会加上单引号 '' 不能防止sql 注入
- 126.mybatis 有几种分页方式?
limit PageHelper
- 127.RowBounds 是一次性查询全部结果吗?为什么?
- 128.mybatis 逻辑分页和物理分页的区别是什么?
物理分页就是数据库本身提供了分页方式,如MySQL的limit,oracle的rownum ,好处是效率高,不好的地方就是不同数据库有不同的搞法。
逻辑分页利用游标分页,好处是所有数据库都统一,坏处就是效率低
- 129.mybatis 是否支持延迟加载?延迟加载的原理是什么?
- 130.说一下 mybatis 的一级缓存和二级缓存?
区别:一级缓存的作用域是一个sqlsession内;二级缓存作用域是针对mapper进行缓存.
一级缓存:
1、第一次发起查询用户id为1的用户信息,先去找缓存中是否有id为1的用户信息,如果没有,从数据库查询用户信息。得到用户信息,将用户信息存储到一级缓存中。
2、如果中间sqlSession去执行commit操作(执行插入、更新、删除),则会清空SqlSession中的一级缓存,这样做的目的为了让缓存中存储的是最新的信息,避免脏读。
3、第二次发起查询用户id为1的用户信息,先去找缓存中是否有id为1的用户信息,缓存中有,直接从缓存中获取用户信息。
小结:一级缓存时执行commit,close,增删改等操作,就会清空当前的一级缓存;当对SqlSession执行更新操作(update、delete、insert)后并执行commit时,不仅清空其自身的一级缓存(执行更新操作的效果),也清空二级缓存(执行commit()的效果)。
二级缓存:
不管是不是相同的session,只要mapper的namespace相同,可能共享缓存,要求:如果开启了二级缓存,那么在关闭sqlsession后(close),才会把该sqlsession一级缓存中的数据添加到namespace的二级缓存中
- 131.mybatis 和 hibernate 的区别有哪些?
MyBatis:机械工具,使用方便,拿来就用,但工作还是要自己来作,不过工具是活的,怎么使由我决定。(小巧、方便、高效、简单、直接、半自动)
Hibernate:智能机器人,但研发它(学习、熟练度)的成本很高,工作都可以摆脱他了,但仅限于它能做的事。(强大、方便、高效、复杂、绕弯子、全自动)
- 132.mybatis 有哪些执行器(Executor)?
- 133.mybatis 分页插件的实现原理是什么?
- 134.mybatis 如何编写一个自定义插件?