Mybatis

  • MyBatis中的#{}和${}区别?

#{}是预编译处理,${}是字符替换,在使用#{}时,Mybatis会将SQL中的#{}替换成?,配合PreparedStatement中 的set方法复制,这样可以有效的防止SQL注入,保证程序运行安全

  • Mybatis有几种分页方式?
  1. 逻辑分页:使用Mybatis自带的RowBounds进行分页,它是一次性查询很多数据,然后在数据中进行检索。
  2. 物理分页:自己手写Sql分页或使用分页插件PageHelper,去数据库中查询指定条数的分页数据的形式。
  • RowBounds是一次性查询全部结果吗?

不是,RowBounds表面是在所有的数据中检索数据,其实并非一次性查询所有数据,因为Mybatis是对 jdbc的封装,在jdbc驱动中有一个Fetch Size的配置,它规定了每次最多从数据库中查询多少条数据, 假如你要查询更多数据,它会在你执行next()的时候,去查询更多的数据。 只是对于jdbc来说,当你调用next()时候会自动帮你完成查询工作。这样的好处可以与小的防止内存溢出。

Mybatis中的逻辑分页和物理分页的区别?

逻辑分页是一次性查询很多数据,然后再在结果中检索分页的数据。这样做的弊端是需要消耗大量的 内存、有内存溢出的风险、对数据库压力较大。 物理分页是从数据库查询指定条数的数据,弥补一次性全部查出的所有数据的种种缺点。

  • Mybatis是否支持延迟加载?原理是什么?
支持,设置lazyloacingEnabled=true.
原理:是调用的时候触发加载,而不是初始化的时候就加载信息。
比如调用a.getB().getName(),这个时候a.getB()的值为null,此时会单独触发实现保存好的关联B
对象的SQL,先查询出来B,然后再调用a.setB(b),而这时候再调用a.getB().getName()就有值了、
  • Mybatis中的一级缓存和二级缓存?
  1. 一级缓存:基于PerpetcualCache的HashMap本地缓存,它的声明周期是和SQLSession一致的,有多个SQLSession或者分布式的环境中数据库操作,可能会出现脏数据。当Session flush或close后,该Session中的所有Cache将被清空,默认一级缓存是开启的。
  2. 二级缓存:也是基于PerpetcualCache的HashMap本地缓存,不同在于其存储的作用域为Mapper级别的,如果多个SQLSession之间需要共享缓存,则需要使用到二级缓存,并且二级缓存可自定义存储资源,如Ehcache。默认不打开二级缓存,要开启二级缓存,使用二级缓存属性类需要实现Serializable序列化接口(可用来保存对象的状态)。
  3. 开启二级缓存数据查询流程:二级缓存--》一级缓存--》数据库。
  4. 缓存更新机制:当某一个作用域(一级缓存Session/二级缓存Mapper)进行了C、U、D操作后,默认该作用域下所有select中的缓存将被clear。
  • Mybatis和hibernate的区别?
  1. 灵活性:Mybatis更加灵活,自己可以写SQL语句,使用较方便。
  2. 可移植性:Mybatis有很多自己写的SQL,可移植性差。
  3. 二级缓存:hibernate拥有更好的二级缓存,它的二级缓存可以自行更换为第三方的二级缓存。
  • Mybatis中有那些执行器?
  1. SimpleExecutor
  2. ReuseExecutor
  3. BatchExecutor
  • Mybatis如何编写一个自定义插件?
  1. Mybatis自定义插件针对Mybatis四大对象(Executor、StatementHandler、ParameterHandler、ResultSetHandler)进行拦截。
  2. Executor:拦截内部执行器,它负责调用StatementHandler操作数据库,并把结果集通过ResultSetHandler进行自动映射,另外它还处理了二级缓存的操作。
  3. StatementHandler:拦截SQL语法构建的处理,它是Mybatis直接和数据库执行SQL脚本的对象,另外它也实现了MyBatis的一级缓存。
  4. ParameterHandler:拦截参数的处理。
  5. ResultSetHandler:拦截结果集的处理。
  • 自定义插件实现关键
  • Mybatis插件要实现Interceptor接口,接口包含的方法
public interface Interceptor {   
   Object intercept(Invocation invocation) throws Throwable;       
   Object plugin(Object target);    
   void setProperties(Properties properties);
}
  • setProperties方法是在Mybatis进行配置插件的时候可以配置自定义相关属性,即:接口实现对象的参数配置;
  • plugin方法是插件用于封装目标对象的,通过该方法我们可以放回目标对象本身,也可以返回一个它的代理,可以决定是否要进行拦截进而决定要返回一个什么样的目标对象,官方提供了
  • 示例:return Plugin.wrap(target,this);
  • intercept方法就是要进行拦截的时候要执行的方法。
  • 官方插件实现:
    @Intercepts({@Signature(type = Executor. class, method = "query",
            args = {MappedStatement. class, Object. class, RowBounds. class, ResultHandler. class})})
    public class TestInterceptor implements Interceptor {
       public Object intercept(Invocation invocation) throws Throwable {
         Object target = invocation. getTarget(); //被代理对象
         Method method = invocation. getMethod(); //代理方法
         Object[] args = invocation. getArgs(); //方法参数
         // do something . . . . . .  方法拦截前执行代码块
         Object result = invocation. proceed();
         // do something . . . . . . . 方法拦截后执行代码块
         return result;
       }
       public Object plugin(Object target) {
         return Plugin. wrap(target, this);
       }
    }
    

     

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值