MyBatis映射器精要

Select

  • 自动映射

    • settings元素的autoMappingBehavior属性

    NONE,取消自动映射
    PARTIAL(默认),仅自动映射
    FULL,自动映射任意复杂的结果集
    - settings元素的MapUnderscoreToCamelCase属性
    > MapUnderscoreToCamelCase为true时,可以实现从数据库字段(下划线分隔)到类属性(驼峰命名)的映射

  • 参数传递

    • Map传参,简单易用,但是可读性不强
    public List selectUser(Map params);
    
    • 注解方式(@Param),简单易用,可读性高,但是如果参数很多的话,会十分繁琐(从代码维护性来看,一般参数不应多于3个)
    public List selectUser(@Param("age") int age, @Param("name") String name);
    
    • JavaBean传参,在参数较多的时候可以使用,属性需要有相应的get/set方法
    public List selectUser(UserParam params);
    

Insert

  • 主键回填
    • 数据库自增主键

    使用keyProperty属性指定哪个是主键字段,使用useGeneratedKeys属性指定主键生成策略
    - 自定义主键策略
    > 使用selectKey元素进行处理
    > selectKey使用灵活,不太可控,而且很容易产生一些意想不到的问题,最好尽量避免使用

Update && Delete

特殊字符串的替换和处理

  • #{param} MyBatis进行预编译处理
  • ${param} MyBatis不进行处理,直接输出到sql语句中,这里需要注意是否存在SQL注入漏洞

MyBatis的映射关系

  • association:一对一关系
  • collection:一对多关系
  • discriminator: 鉴别器,允许用户根据特定的条件去关联不同的结果集。

多对多关系较复杂,一般在设计表的时候会拆分成两个一对多形式,通过中间表关联

N+1与延迟加载

  • N+1问题:简单说来就是表A对表B和表C是一对多的关系,那么查询表A的10条记录的话,就要联带查询表B和表C的N+10条记录,问题是我们明明只需要表A的信息。。。
  • 延迟加载处理N+1问题
    • 使用到级联数据的时候才去执行查询
    • 通过lazyLoadingEnabled属性开启/关闭延迟加载
    • 通过aggressiveLazyLoading属性启用/禁用层级加载的策略

MyBatis系统缓存

  • 一级缓存
    • 作用范围:同一个SqlSession
    • 使用条件:默认开启
  • 二级缓存
    • 作用范围:SqlSessionFactory,可以提供给各个SqlSession共享
    • 使用条件:需要手动开启,同时对应的实体类必须是可序列化的
    • 缓存配置:


      eviction:缓存回收策略
      flushInterval:刷新间隔时间,单位毫秒
      size:缓存对象的最大值
      readOnly:缓存数据是否可修改

MyBatis自定义缓存

  • 比如可以将结果缓存至Redis中
  • 需要实现org.apache.ibatis.cache.Cache接口
public final class MyCache implements Cache {}
  • 配置自定义缓存

你可能感兴趣的:(MyBatis映射器精要)