mybatis 鉴别其_mybatis文件映射之鉴别器discriminator标签

mybatis可以使用鉴别器判断某列的值,然后根据某列的值改变封装行为。

比如说:

如果是女生(gender=0)我们将部门信息提取出来,否则不提取;

如果是男生(gender=1),把last_name的值赋值给email;

EmployeeMapper.xml

column="d_id">

select * from tbl_employee where id=#{id}

说明:distriminator中的javaType指定数据库中字段对应着java中的属性的类型,column属性为列名称。case标签中value属性标识数据库中列的值,resultType指定封装的结果类型,不可少。

DepartmentMapper.xml

select * from tbl_department where id=#{id}

进行测试:

package com.gong.mybatis.test;

import java.io.IOException;

import java.io.InputStream;

import java.util.List;

import java.util.Map;

import org.apache.ibatis.io.Resources;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import org.junit.Test;

import com.gong.mybatis.bean.Department;

import com.gong.mybatis.bean.Employee;

import com.gong.mybatis.dao.DepartmentMapper;

import com.gong.mybatis.dao.EmployeeMapperPlus;

public class TestMybatis2 {

public SqlSessionFactory getSqlSessionFactory() throws IOException {

String resource = "mybatis-config.xml";

InputStream is = Resources.getResourceAsStream(resource);

return new SqlSessionFactoryBuilder().build(is);

}

@Test

public void test() throws IOException {

SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();

SqlSession openSession = sqlSessionFactory.openSession();

try {

EmployeeMapperPlus mapper = openSession.getMapper(EmployeeMapperPlus.class);

Employee employee = mapper.getEmpByIdStep(3);

System.out.println(employee.getLastName());

System.out.println(employee.getDept());

openSession.commit();

} finally {

openSession.close();

}

}

}

首先测试的是gender=0的情况:

DEBUG 01-20 20:47:37,503 ==> Preparing: select * from tbl_employee where id=? (BaseJdbcLogger.java:145)

DEBUG 01-20 20:47:37,590 ==> Parameters: 3(Integer) (BaseJdbcLogger.java:145)

DEBUG 01-20 20:47:37,757 <== Total: 1 (BaseJdbcLogger.java:145)

小红

DEBUG 01-20 20:47:37,759 ==> Preparing: select * from tbl_department where id=? (BaseJdbcLogger.java:145)

DEBUG 01-20 20:47:37,760 ==> Parameters: 1(Integer) (BaseJdbcLogger.java:145)

DEBUG 01-20 20:47:37,763 <== Total: 1 (BaseJdbcLogger.java:145)

Department [id=1, deptName=开发部]

可以查到部门的信息。

接下来是gender=1的情况:

Employee employee = mapper.getEmpByIdStep(1);

DEBUG 01-20 20:53:32,581 ==> Preparing: select * from tbl_employee where id=? (BaseJdbcLogger.java:145)

DEBUG 01-20 20:53:32,647 ==> Parameters: 1(Integer) (BaseJdbcLogger.java:145)

DEBUG 01-20 20:53:32,708 <== Total: 1 (BaseJdbcLogger.java:145)

xiximayou

null

发现部门信息是查不到的。

再进行gender=1时的情况:

Employee employee = mapper.getEmpByIdStep(1);

System.out.println(employee);

System.out.println(employee.getDept());

DEBUG 01-20 20:54:39,440 ==> Preparing: select * from tbl_employee where id=? (BaseJdbcLogger.java:145)

DEBUG 01-20 20:54:39,480 ==> Parameters: 1(Integer) (BaseJdbcLogger.java:145)

DEBUG 01-20 20:54:39,555 <== Total: 1 (BaseJdbcLogger.java:145)

Employee [id=1, lastName=xiximayou, gender=1, email=xiximayou, dept=null]

null

email被修改,且部门信息查不到。

gender=0的情况:

Employee employee = mapper.getEmpByIdStep(3);

System.out.println(employee);

System.out.println(employee.getDept());

DEBUG 01-20 20:56:19,177 ==> Preparing: select * from tbl_employee where id=? (BaseJdbcLogger.java:145)

DEBUG 01-20 20:56:19,221 ==> Parameters: 3(Integer) (BaseJdbcLogger.java:145)

DEBUG 01-20 20:56:19,384 <== Total: 1 (BaseJdbcLogger.java:145)

DEBUG 01-20 20:56:19,385 ==> Preparing: select * from tbl_department where id=? (BaseJdbcLogger.java:145)

DEBUG 01-20 20:56:19,386 ==> Parameters: 1(Integer) (BaseJdbcLogger.java:145)

DEBUG 01-20 20:56:19,389 <== Total: 1 (BaseJdbcLogger.java:145)

Employee [id=3, lastName=小红, gender=0, email=xiaohong@qq.com, dept=Department [id=1, deptName=开发部]]

Department [id=1, deptName=开发部]

email未被修改,且可以查到部门的信息。

标签:01,20,java,鉴别器,DEBUG,employee,mybatis,discriminator,id

来源: https://www.cnblogs.com/xiximayou/p/12219414.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值