Select
-
自动映射
- settings元素的autoMappingBehavior属性
NONE,取消自动映射
PARTIAL(默认),仅自动映射
FULL,自动映射任意复杂的结果集
- settings元素的MapUnderscoreToCamelCase属性
> MapUnderscoreToCamelCase为true时,可以实现从数据库字段(下划线分隔)到类属性(驼峰命名)的映射 -
参数传递
- Map传参,简单易用,但是可读性不强
public List<User> selectUser(Map<String, Object> params);
- 注解方式(@Param),简单易用,可读性高,但是如果参数很多的话,会十分繁琐(从代码维护性来看,一般参数不应多于3个)
public List<User> selectUser(@Param("age") int age, @Param("name") String name);
- JavaBean传参,在参数较多的时候可以使用,属性需要有相应的get/set方法
public List<User> 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共享
- 使用条件:需要手动开启,同时对应的实体类必须是可序列化的
- 缓存配置:
<cache eviction="LRU" flushInterval="100000" size="1024" readOnly="true" />
eviction:缓存回收策略
flushInterval:刷新间隔时间,单位毫秒
size:缓存对象的最大值
readOnly:缓存数据是否可修改
MyBatis自定义缓存
- 比如可以将结果缓存至Redis中
- 需要实现org.apache.ibatis.cache.Cache接口
public final class MyCache implements Cache {}
- 配置自定义缓存
<cache type="xxx.xxx.MyCache" />