目录
概述
现在有两个表员工表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))