本文内容来自尚硅谷
本文主要是说明鉴别器的用法,这个鉴别器用的不是很多。代码可以使用MyBatis总结(二十六)--任务35:MyBatis_映射文件_select_resultMap_关联查询_collection分步查询&延迟加载中的代码。也可以自己编写。这里就直接基于MyBatis总结(二十六)--任务35:MyBatis_映射文件_select_resultMap_关联查询_collection分步查询&延迟加载的代码来说明
xml配置如下
如果得到的gender值为0(是女生),则执行case中value值为0的代码即查询出id值就行了
如果得到的gender值为1(是男生),查询出名称,地址等信息不用查询出id值
<!-- =======================鉴别器============================ -->
<!-- <discriminator javaType=""></discriminator>
鉴别器:mybatis可以使用discriminator判断某列的值,然后根据某列的值改变封装行为
封装Employee:
如果查出的是女生:就把部门信息查询出来,否则不查询;
如果是男生,把last_name这一列的值赋值给email;
-->
<resultMap type="com.atguigu.mybatis.bean.Employee" id="MyEmpDis">
<id column="id" property="id"/>
<result column="last_name" property="lastName"/>
<result column="email" property="email"/>
<result column="gender" property="gender"/>
<!--
column:指定判定的列名
javaType:列值对应的java类型 -->
<discriminator javaType="string" column="gender">
<!--女生 resultType:指定封装的结果类型;不能缺少。/resultMap-->
<case value="0" resultType="com.atguigu.mybatis.bean.Employee">
<association property="dept"
select="com.atguigu.mybatis.dao.DepartmentMapper.getDeptById"
column="d_id">
</association>
</case>
<!--男生 ;如果是男生,把last_name这一列的值赋值给email; -->
<case value="1" resultType="com.atguigu.mybatis.bean.Employee">
<id column="id" property="id"/>
<result column="last_name" property="lastName"/>
<result column="last_name" property="email"/>
<result column="gender" property="gender"/>
</case>
</discriminator>
</resultMap>
版权声明:本文不是「本站」原创文章,版权归原作者所有 | 原文地址: