Mybatis学习之多对一映射处理

目录

概述

方式一级联方式处理映射关系

方式二使用association处理映射关系

方式三分步查询

1.查询员工信息

2.查询部门信息


概述

现在有两个表员工表emp以及部门表dept。一个员工只在一个部门,一个部门可以有多个员工。表的结构如下

emp实体类

public class Emp {
    private Integer eid;
    private String empName;
    private Integer empAge;
    private String empSex;
    private String empEmail;
    private Dept dept;
}

现在表中的数据如下图

 

对于多对一映射处理有3三方式可以实现

方式一级联方式处理映射关系

mapper接口中的方法

    /**
     * 根据员工的主键id查询出员工以及其所在部门的信息
     * @param eid
     * @return
     */
    Emp getEmpById(@Param("eid") int eid);



xml配置文件中的sql语句
 <resultMap id="empDeResult" type="com.csdn.beans.Emp">
        <id property="eid" column="eid"></id>
        <result property="empName" column="emp_name"/>
        <result property="empAge" column="emp_age"/>
        <result property="empSex" column="emp_sex"/>
        <result property="empEmail" column="emp_email"/>
        <result property="dept.did" column="did"/>
        <result property="dept.dname" column="dname"/>
    </resultMap>

    <select id="getEmpById" resultMap="empDeResult">
        select emp.emp_name
             , emp.emp_age
             , emp.emp_sex
             , emp.emp_email
             , emp.eid
             , dept.did as did
             , dept.dname as dname
        from emp
                 left join dept on emp.dept_id = dept.did
        where emp.eid = #{eid}
    </select>



测试方法
  @Test
    public void test2(){
        SqlSession sqlSession= SqlSessionUtil.getSqlSession();
        EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
        Emp emp = mapper.getEmpById(5);
        System.out.println(emp);
    }


运行结果
Emp(eid=5, empName=田七, empAge=33, empSex=女, empEmail=bac@126.com, dept=Dept(did=3, dname=部门C))

方式二使用association处理映射关系

只需要将之前的xml文件修改如下即可

<resultMap id="empDeResult" type="com.csdn.beans.Emp">
        <id property="eid" column="eid"></id>
        <result property="empName" column="emp_name"/>
        <result property="empAge" column="emp_age"/>
        <result property="empSex" column="emp_sex"/>
        <result property="empEmail" column="emp_email"/>
        <association property="dept" javaType="com.csdn.beans.Dept">
            <id property="did" column="did"/>
            <result property="dname" column="dname"/>
        </association>
    </resultMap>

    <select id="getEmpById" resultMap="empDeResult">
        select emp.emp_name
             , emp.emp_age
             , emp.emp_sex
             , emp.emp_email
             , emp.eid
             , dept.did as did
             , dept.dname as dname
        from emp
                 left join dept on emp.dept_id = dept.did
        where emp.eid = #{eid}
    </select>

方式三分步查询

1.查询员工信息

 接口中的方法
/**
     * 通过分步查询,员工及所对应的部门信息
     * 分步查询第一步:查询员工信息
     * @param eid
     * @return
     */
    Emp getEmpAndDeptOne(@Param("eid") Integer eid);





xml中的实现
 <resultMap id="empDeResult" type="com.csdn.beans.Emp">
        <id property="eid" column="eid"></id>
        <result property="empName" column="emp_name"/>
        <result property="empAge" column="emp_age"/>
        <result property="empSex" column="emp_sex"/>
        <result property="empEmail" column="emp_email"/>
       <association property="dept" javaType="com.aoshen.csdn.Dept"
                    select="com.csdn.mapper.DeptMapper.getEmpAndDeptTwo"
                    column="dd" ></association>
    </resultMap>

    <select id="getEmpAndDeptOne" resultMap="empDeResult">
        select emp_name
             , emp_age
             , emp_sex
             , emp_email
             , eid,
               dept_id as dd
        from emp where emp.eid=#{eid}
    </select>

2.查询部门信息

deptmapper接口中方法
Dept getEmpAndDeptTwo(@Param("did") Integer did);

xml中实现
 <select id="getEmpAndDeptTwo" resultType="com.aoshen.beans.Dept">
        select * from dept where did=#{did}
    </select>

测试

 SqlSession sqlSession= SqlSessionUtil.getSqlSession();
        EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
        Emp emp = mapper.getEmpAndDeptOne(5);
        System.out.println(emp);


结果

Emp(eid=5, empName=田七, empAge=33, empSex=女, empEmail=bac@126.com, dept=Dept(did=3, dname=部门C))

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

喜欢编程的夏先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值