概述
级联是在resultMap标签中配置。级联不是必须的,级联的好处是获取关联数据十分便捷,但是级联过多会增加系统的复杂度,同事降低系统的性能,次增彼减,所以记录超过3层时,就不要考虑使用级联了,因为这样会造成多个对象的关联,导致系统的耦合、负载和难以维护。
MyBatis中的级联分2种:
1.一对一(association)
2.一对多(collection)
一、一对一
A表一对一B表情况下A对象当中有外键关联的B表的对象作为属性,A对象中有一个B对象属性。当查A对象时,如果想把B对象属性同时获取,有三种方式。
三种方式:
1、多表联合查询,即A表和B表联合查询,同事查出A、B表的字段,然后配置resultMap标签。
resultMap标签的配置如下:
<resultMap id="AResultMap" type="com.A" >
<id column="A_ID" property="AId" jdbcType="INTEGER" />
<result column="ASSET_NO" property="assetNo" jdbcType="VARCHAR" />
<result column="AREA_CODE" property="areaCode" jdbcType="VARCHAR" />
<result column="A_ADDR" property=AAddr" jdbcType="VARCHAR" />
<!-- 一下是对A对象中B的属性的映射配置 -->
<result column="B_id" property="b.BId"/>
<result column="ONLINE_DATE" property="b.onlineDate"/>
<result column="LAST_COMM_TIME" property="b.lastCommTime"/>
<result column="STATUS_CODE" property="b.statusCode"/>
</resultMap>
2、多表联合查询,即A表和B表联合查询,同事查出A、B表的字段,然后通过association标签配置resultMap标签。
resultMap标签的配置如下:
<resultMap id="AResultMap" type="com.A" >
<id column="A_ID" property="AId" jdbcType="INTEGER" />
<result column="ASSET_NO" property="assetNo" jdbcType="VARCHAR" />
<result column="AREA_CODE" property="areaCode" jdbcType="VARCHAR" />
<result column="A_ADDR" property=AAddr" jdbcType="VARCHAR" />
<!-- 一下是对A对象中B的属性的映射配置 -->
<association property="b" javaType="com.B">
<id column="B_id" property="bId"/>
<result column="ONLINE_DATE" property="onlineDate"/>
<result column="LAST_COMM_TIME" property="lastCommTime"/>
<result column="STATUS_CODE" property="statusCode"/>
</association>
</resultMap>
3、只查询A表字段,然后通过外键调用查询B表的select标签查询B表对象,通过association标签配置resultMap标签。
resultMap标签的配置如下:
<resultMap id="AResultMap" type="com.A" >
<id column="A_ID" property="AId" jdbcType="INTEGER" />
<result column="ASSET_NO" property="assetNo" jdbcType="VARCHAR" />
<result column="AREA_CODE" property="areaCode" jdbcType="VARCHAR" />
<result column="A_ADDR" property=AAddr" jdbcType="VARCHAR" />
<!-- 一下是对A对象中B的属性的映射配置 -->
<association property="b" column="B_ID" select="com.BMapper.selectBById"/>
</resultMap>
第三种方式只需要单表查询,但需要分别查询A表和B表,通过外键调用B表的select。association标签中调用的B表的select不通过BMapper的接口,因此在BMapper文件对应的接口中可以不写selectBById方法。
二、一对多
B一对多A只需在resultMap标签中配置association标签即可。
<resultMap type="B" id="getB">
<result property="Bid" column="Bid" />
<collection property="AList" column="Bid" javaType="list" select="getAListByBid"/>
</resultMap>
最后
以上就是义气冰棍为你收集整理的mybatis级联查询的全部内容,希望文章能够帮你解决mybatis级联查询所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复