标签:需要 collect 构造方法 str 特定 版本 nec sql java接口
resultMap的作用是定义映射规则、级联的更新、定制类型转化器等。resultMap定义的主要是一个结果集的映射关系,也就是SQL到Java Bean的映射关系的定义,它也支持级联等特性。
resultMap主要包含的元素有 constructor(配置构造方法)、id(表示哪个键是主键,允许有多个主键构成联合主键)、result(配置POJO到SQL列名的映射关系)、association和collection和discriminator(配置级联问题)。一条SQL语句执行后,就会返回结果,而结果可以使用map存储,也可以使用POJO 进行存储。
Mybatis中的级联分为三种:
①鉴别器(discriminator):它是一个根据某些条件决定采用具体实现类级联的方案,比如体检表要分性别去区分。
②一对一(association):比如学生证和学生就是一对一的关系,雇员和工牌就是一对一的级联。
③一对多(collection):比如班主任和学生就是一对多的关系。
在实际业务中,级联关系更为复杂,可以看下图的分析:
假设现在有N 个关联关系完成了级联,那么只要再加入一个关联关系,就变成了N+1个级联,所有的级联SQL都会被执行,这样显然造成了很多资源的浪费,这就是所谓的 N+1问题。为了应对这个问题,Mybatis提供了延迟加载的功能。即一次性地把常用的级联数据通过SQL直接查询出来,而对于那些不常用的级联数据不要取出,而是等待要用时才取出,这些不常用的数据可以采用延迟加载的功能。
在Mybatis的setting的配置中存在两个元素可以配置级联。
①lazyLoadingEnabled是延迟加载的开关。在开启时,所有的关联对象都会被延迟加载。在特定关联关系中,可以通过设置fetchType属性来覆盖该项的开关状态,默认值是false。
②aggressiveLazyLoading:当启用时,对任意延迟属性的调用会使带有延迟加载属性的对象完整加载,反之,则每种属性按需加载。在版本3.4.1之前默认是true,后面默认是false。
在Mybatis中允许使用缓存,缓存一般都放置在可高速读/写的存储器上,比如服务器的内存,它能有效提高系统的性能,因为数据库在大部分场景下时把存储在磁盘上的数据索引出来。
Mybatis中的缓存可以分为一级缓存和二级缓存。一级缓存是在SqlSession上的缓存,二级缓存是在SqlSessionFactory 上的缓存。默认情况下,即没有任何配置的情况下,Mybatis会默认开启一级缓存,这个缓存不需要POJO 对象可序列化(实现java.io.Serialization接口)。
标签:需要 collect 构造方法 str 特定 版本 nec sql java接口
原文地址:https://www.cnblogs.com/Demrystv/p/9196554.html