1、mybatis中#{} 和 ${}的区别是什么?
- #{}是编译预处理,mybatis在处理#{}时候,会将sql中的#{}替换成?号,通过preparedStatement的set方法来赋值。
- ${}是字符串替换,mybatis在处理${}时候,直接将${}替换成变量的值。
- 使用#{}可以有效的防止sql注入,提高系统的安全性。
2、mybatis有几种分页的方式?
- 数组分页
- sql分页
- 拦截器分页
- RowBounds分页
3、mybatis逻辑分页和物理分页的区别?
- 物理分页 使用limit,逻辑分页,访问一次数据库,返回全量数据后对其进行分页
- 速度上没有明显的差异
- 物理分页总是优于逻辑分页的,没必要将数据库端的压力转移到应用端来,就算是提高了一些速度,也会在其他性能上补回来。
4、mybaits是否支持延迟加载?延迟加载的原理是什么?
mybatis仅支持关联对象和集合对象的延迟加载,关联对象指的一对一查询,集合对象指的是一对多查询。在mybatis的配置文件中可以lazyLoadingEnabled = true / false来配置是否允许延迟加载。
延迟加载的原理:
使用CGLIB创建目标对象的代理对象,调用目标方法的时候,进入拦截器的方法,比如调用a.getb().getName,拦截器invoke()方法发现a.getb()的值是null,那么就会单独发送事先保存好的查询关联B对象的sql,把B查询上来,然后调用a.setB(b),于是a对象的b属性就有值了,接着就可以完成a.getb().getName(),这就是延迟加载的基本原理。
5、说一下mybatis的一级缓存和二级缓存?
一级缓存:
二级缓存:
6、mybatis和hibernate的区别有哪些?
- mybatis与hibernate不同,它不完全是一个ORM(对象关系映射)框架,需要程序员自己编写sql。
- mybatis直接编写原生的sql,可以严格的控制性能,灵活度高,比较适用于对于关系型数据库要求不高的软件开发。但是无法做到于数据库无关,如果需要实现支持多种数据库的软件,就需要成产大量的mapper文件。
- hibernate对象/关系映射能力强,与数据无关性好
7、mybatis有哪些执行器?
mybatis有三种基本的执行器:
- SimpleExecutor:每次执行update/select,就会开启一个statement对象,用完立刻关闭这个statement对象。
- ReuseExecutor:重复使用statement对象,每次执行update/select时候,以sql为key去查找statement对象,如果有就使用,没有就创建一个,用完也不关闭,而是放在map中,留给下一次使用。
- BatchExecutor:执行update语句时候(JDBC的批处理不支持select语句),将所有的sql都添加到批处理中,等待统一执行,它会缓存多个statement对象,每一个statement对象都是在addbatch()完毕后,等待逐一执行executorBatch()批处理。
8、如何设置mybatis所使用的执行器
在Mybatis配置文件中,可以指定默认的ExecutorType执行器类型,也可以手动给DefaultSqlSessionFactory的创建SqlSession的方法传递ExecutorType类型参数。