面试题-Java基础(十三)- Mybatis

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类型参数。

下一节 RabbitMQ

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值