在特定的情况下使用不同的pojo进行关联, 鉴别器元素就是被设计来处理这个情况的。鉴别器非常容易理解,因为它的表现很像 Java 语言中的 switch 语句
discriminator 标签常用的两个属性如下:
column:该属性用于设置要进行鉴别比较值的列 。
javaType:该属性用于指定列的类型,保证使用相同的 Java 类型来比较值。
discriminator 标签可以有1个或多个 case 标签, case 标签包含以下三个属性 。
value : 该值为 discriminator 指定 column 用来匹配的值 。
resultMap : 当column的值和value的值匹配时,可以配置使用resultMap指定的映射,resultMap优先级高于 resultType 。
resultType : 当 column 的值和 value 的值匹配时,用于配置使用 resultType指定的映射。
示例代码:
<select id="selectUserHealthReport" resultMap="userAndHealthReport">
select
<include refid="Base_Column_List" />
from t_user a
</select>
<resultMap id="userAndHealthReport" extends="BaseResultMap" type="TUser">
<discriminator column="sex" javaType="int">
<case value="1" resultMap="userAndHealthReportMale"/>
<case value="2" resultMap="userAndHealthReportFemale"/>
</discriminator>
</resultMap>
主要,子resultMap必须extends是 userAndHealthReport
<resultMap id="userAndHealthReportMale" extends="userAndHealthReport" type="TUser">
<collection property="healthReports" column="id"
select= "com.caojiulu.mybatis.mapper.THealthReportMaleMapper.selectByUserId"></collection>
</resultMap>
<resultMap id="userAndHealthReportFemale" extends="userAndHealthReport" type="TUser">
<collection property="healthReports" column="id"
select= "com.caojiulu.mybatis.mapper.THealthReportFemaleMapper.selectByUserId"></collection>
</resultMap>
标签:value,column,标签,resultMap,源码,鉴别器,Mybatis,discriminator From: https://blog.51cto.com/u_14906615/5899410