要求:查询一个员工的时候,把他对应的部门也查询出来

实现(其他配置这里不作说明,框架基于spring_springMVC_mybatis_oracle):

如有不对或不适的地方,请多多指教。

1、新建Emp实体类(get 和set方法省略)

package app.cmsg.entity;

import java.sql.Date;

public class Emp {
private Integer f_empno;
private String f_ename;
private String f_ejob;
private Integer f_emgr;
private Date f_hiredate;
private Double f_sal;
private Double f_comm;
private Integer f_deptno;

...

省略get和set方法

}

/**
* 关联属性,封装dept员工对应的部门信息
* @return
*/
private Dept dept;

2 、新建关联属性对应的部门实体类

package app.cmsg.entity;

public class Dept {
private Integer f_deptno;
private String f_dname;
private String f_loc;

...

省略get和set方法

}

3 EmpDao中添加根据员工ID查询员工的方法

package app.cmsg.dao;

import java.util.List;

import app.cmsg.annotation.MyBatisRepostory;
import app.cmsg.entity.Condition;
import app.cmsg.entity.Emp;

/**
* 创建EmpDao接口并增加查询全部员工的方法
* @author 4750g
* 员工表的Dao组件
*/
@MyBatisRepostory //<!--mybatis注解 app.cmsg.annotation.MyBatisRepostory需要自定义-->applicationContext.xml中配置的
public interface EmpDao {
Emp findById(int f_empno);
}

4 配置mapper.xml文件

<select id="findById" parameterType="java.lang.Integer" resultMap="empMap">
  select * from t_emp t where t.f_empno = #{id}
</select>
<resultMap type="app.cmsg.entity.Emp" id="empMap">
  <association property="dept" column="f_deptno"  javaType="app.cmsg.entity.Dept" select="findByDeptApp">
</association>
</resultMap>
<select id="findByDeptApp" parameterType="java.lang.Integer"  resultType="app.cmsg.entity.Dept">
  select * from t_dept t where t.f_deptno = #{f_deptno}
</select>

先是请求id为findById的select映射,然后得到一个id为empMap的ResultMap对象,在对应的resultMap的返回
类型是一个app.cmsg.entity.Emp对象,其中只有一个association节点,其仍会把对应的id等属性赋给app.cmsg.entity.Emp对象,
这就是MyBatis拥有自动封装功能,只要你提供了返回类型,MyBatis会根据自己的判断来利用查询结果封装对应的对象,MyBatis的自
身判断是把查询的field或其对应的别名与返回对象的属性进行比较,如果相匹配且类型也相匹配,MyBatis则会对其进行赋值。在上面对应的
resultMap中关联了一个dept属性,其对应的JAVA类型为Dept,在上述的写法中,关联对象是通过子查询来进行关联的,当然也可以直接
通过关联查询来进行关联。上面的association子节点中,Property属性表示是resultMap返回类型的哪个关联属性,对于上面的例子
就是Emp管理的dept属性;select表示进行哪个select映射来映射对应的关联属性,即会去请求id为select所对应的值的select映射 来
查询出其所关联的属性对象;Column表示当前关联对象在id为empMap的resultMap中所对应的键值对,该键值对将作为对关联对象子查询的参数,
即将把在findById中查询出来的dept属性的值作为参数传给进行关联对象dept的子查询findByDeptApp的参数;javaType表示当前关联
对象在JAVA中是什么类型。

5 添加测试类(需要引入Junit包)

package app.cmsg.test;

import java.sql.Date;
import java.util.ArrayList;
import java.util.List;

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import app.cmsg.dao.EmpDao;
import app.cmsg.entity.Condition;
import app.cmsg.entity.Emp;

public class JUintTest {

/**
* 多对一嵌套查询映射
* 根据ID查询一条员工记录,并查询他们所在的部门
*/
@Test
public void findById(){
ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml");
EmpDao empDao = ctx.getBean(EmpDao.class);
Emp emp = empDao.findById(12);
System.out.println(
  emp.getF_empno()+", "+
  emp.getF_ename()+", "+
  emp.getF_ejob()+", "+
  emp.getDept().getF_deptno()+", "+
  emp.getDept().getF_dname()+", "+
  emp.getDept().getF_loc()

);

最后控制台打印出的结果

mybatis一对一嵌套查询的更多相关文章

  1. Mybatis一对一关联查询

    有两张表,老师表teacher和班级表class,一个class班级对应一个teacher,一个teacher对应一个class 需求是根据班级id查询班级信息(带老师的信息) 创建teacher和c ...

  2. mybatis的嵌套查询(嵌套查询nested select和嵌套结果nested results查询)区别

    (转自:http://blog.csdn.net/canot/article/details/51485955) Mybatis表现关联关系比hibernate简单,没有分那么细致one-to-man ...

  3. mybatis的嵌套查询与嵌套结果查询的不同

    原文:https://blog.csdn.net/qq_39706071/article/details/85156840 实体类: 嵌套查询mapper方法:嵌套查询的弊端:即嵌套查询的N+1问题尽 ...

  4. MyBatis学习(四)MyBatis一对一关联查询

    一对一关联查询即.两张表通过外键进行关联.从而达到查询外键直接获得两张表的信息.本文基于业务拓展类的方式实现. 项目骨架 配置文件conf.xml和db.properties前几节讲过.这里就不细说了 ...

  5. mybatis一对一关联查询——(八)

    1.需求 查询所有订单信息,关联查询下单用户信息. 注意: 因为一个订单信息只会是一个人下的订单,所以从查询订单信息出发关联查询用户信息为一对一查询.如果从用户信息出发查询用户下的订单信息则为一对多查 ...

  6. MyBatis 一对一关联查询

    xml文件: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC & ...

  7. 五 Mybatis一对一关联查询的两种方式(基于resultType&基于resultMap)

    关联查询: 一个用户对应多个订单,一个订单只有一个用户 订单关联用户:两种方式 一:基于resultTYpe,一个与表关系一样的pojo实现 主表订单,从表用户 首先要有一个与关联查询表关系一样的po ...

  8. MyBatis初级实战之五:一对一关联查询

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  9. Mybatis之关联查询

    一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关 ...

随机推荐

  1. C# 索引器简介

    索引器是一种特殊的类成员,它能够让对象以类似数组的方式来存取,是程序看起来更为直观,更容易编写. 1.索引器的定义 C#中的类成员可以是任意类型,包括数组和集合.当一个类包含了数组和集合成员时,索引器 ...

  2. 历上最强的音乐播放器(jetA…

    原文地址:历上最强的音乐播放器(jetAudio-8.0.5.320-Plus-VX-完全汉化版)下载作者:盖世天星 历上最强的音乐播放器(jetAudio-8.0.5.320-Plus-VX-完全汉 ...

  3. IPsec_VPN实现技术【转载】

    GRE Tunnel GRE Tunnel(General Routing Encapsulation 通用路由封装)是一种非常简单的VPN(Virtual Private Network 虚拟专用网 ...

  4. 团队作业8——第二次项目冲刺(Beta阶段)--5.23 third day

    团队作业8--第二次项目冲刺(Beta阶段)--5.23 third day Day three: 会议照片 项目进展 今天是beta冲刺的第三天,组长回到了队伍当中,正式开始改进alpha中存在的功 ...

  5. Web编程:JSP环境安装与配置

    Web服务器:Tomcat 数据库服务器:暂时未使用 集成开发环境:eclipse 要运行JSP程序,首先要安装JDK(Java Developer Kit),并且还要配置运行Java程序的环境变量. ...

  6. spring+mybatis的简单配置示例

    简单代码结构: //Book.java package com.hts.entity; public class Book { private String id; private String bo ...

  7. 201521123073 《Java程序设计》第8周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结集合与泛型相关内容. 1.2 选做:收集你认为有用的代码片段 (1)集合里面获取对象的时候我们必须进行强制类型转换. List st ...

  8. 201521123067《Java程序设计》第1周学习总结

    1.本周学习总结 在本周的java学习中,我知道了java的发展历程,JDK和JRE以及JVM的区别与联系,并学习了如何安装Eclipse和搭建java的环境,编写出了第一个java程序,明白了jav ...

  9. 201521123102 《Java程序设计》第1周学习总结

    #1. 本周学习总结(1)初步了解java程序的运行环境,通过命令行语句编译简单的java程序(2)使用notepad编写,cmd下进入文件夹编译程序(3)学习使用各种快捷键补全代码(4)能够区别jd ...

  10. 201521123049 《JAVA程序设计》 第11周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2. 书面作业 本次PTA作业题集多线程 1.互斥访问与同步访问 完成题集4-4(互斥访问)与4-5(同步访问) ...