使用resultMap定义查询结果集,实现关联查询
接下来介绍resultMap定义查询结果集,实现关联查询
1 首先在接口中定义操作的方法
public interface EmployeeMapperPlus {
public Employee getEmpAndDept(Integer id);
}
2在xml里进行配置
<!--第一种进行配置
联合查询:级联属性封装结果集
	  -->
	<resultMap type="com.atguigu.mybatis.bean.Employee" id="MyDifEmp">
		<id column="id" property="id"/>
		<result column="last_name" property="lastName"/>
		<result column="gender" property="gender"/>
		<result column="did" property="dept.id"/>
		<result column="departmentName" property="dept.departmentName"/>
	</resultMap>
<!-- 
第二种配置使用association定义关联的单个对象的封装规则;
	 -->
	<resultMap type="com.atguigu.mybatis.bean.Employee" id="MyDifEmp2">
		<id column="id" property="id"/>
		<result column="last_name" property="lastName"/>
		<result column="gender" property="gender"/>
<!--  association可以指定联合的javaBean对象
		property="dept":指定哪个属性是联合的对象
		javaType:指定这个属性对象的类型[不能省略]
		-->
		<association property="dept" javaType="com.atguigu.mybatis.bean.Department">
			<id column="did" property="id"/>
			<result column="departmentName" property="departmentName"/>
		</association>
	</resultMap>
	<!--  public Employee getEmpAndDept(Integer id);-->
	<select id="getEmpAndDept" resultMap="MyDifEmp2">
		SELECT e.id id,e.last_name last_name,e.email email ,e.gender gender,e.did eedid,
		d.id did,d.dname departmentName FROM tbl_employee e,department d
		WHERE e.did=d.id AND e.id=#{id}
	</select>
3在junit里进行测试
@Test
	public void test05() throws IOException{
		SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
		SqlSession openSession = sqlSessionFactory.openSession();
		try{
			EmployeeMapperPlus mapper = openSession.getMapper(EmployeeMapperPlus.class);
			Employee empAndDept = mapper.getEmpAndDept(1);
			System.out.println(empAndDept);
			System.out.println(empAndDept.getDept());
}finally{
			openSession.close();
		}
}
使用resultMap定义查询结果集,实现关联查询的更多相关文章
- MyBatis关联查询,一对多关联查询
		实体关系图,一个国家对应多个城市 一对多关联查询可用三种方式实现: 单步查询,利用collection标签为级联属性赋值: 分步查询: 利用association标签进行分步查询: 利用collect ... 
- Oracle - 查询语句 - 多表关联查询
		/* SQL语句的历史版本 SQL89 比较多 SQL92 SQL99 多表关联查询 笛卡尔积 等值关联查询 非等值关联查询 左外连接 右外连接 全外连接 自连接 */ --------------- ... 
- 子查询优化成join关联查询时要注意一对多关系
		mysql> select * from t where t.id in (select t1.tid from t1); +------+ | id | +------+ | +------+ ... 
- sql遍历查询结果sql循环查询结果集sql循环查询
		--查询表B,把查询到的数据插入临时表#A中,根据表B 的ID 进行排序:表#A中 的 i 字段 由1开始增加排序: SELECT ROW_NUMBER() OVER ( ORDER ... 
- Mybatis3.1-[tp-30-31]-select_resultMap_关联查询_级联属性封装结果__association定义关联对象封装规则
		笔记要点 出错分析与总结 在全局配置中,映射dao包下的全部: <mapper> <package name="com.dao"/> </mapper ... 
- 关联查询resultMap使用规则总结——(十一)
		resultType: 作用: 将查询结果按照sql列名pojo属性名一致性映射到pojo中. 场合: 常见一些明细记录的展示,比如用户购买商品明细,将关联查询信息全部展示在页面时,此时可直接使用re ... 
- MyBatis-Plus不写任何resultMap和SQL执行一对一、一对多、多对多关联查询
		对于一对一,一对多的关联查询,Mybatis-Plus官方示例(mybatis-plus-sample-resultmap)在处理时,需要编写查询方法及配置resultMap,并且写SQL. 为了简化 ... 
- MyBatis 实践 -动态SQL/关联查询
		MyBatis 实践 标签: Java与存储 动态SQL 动态SQL提供了对SQL语句的灵活操作,通过表达式进行判断,对SQL进行拼接/组装. if 对查询条件进行判断,如果输入参数不为空才进行查询条 ... 
- Spring+SpringMVC+MyBatis深入学习及搭建(六)——MyBatis关联查询
		转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6923464.html 前面有将到:Spring+SpringMVC+MyBatis深入学习及搭建(五)--动 ... 
- JAVAEE——Mybatis第二天:输入和输出映射、动态sql、关联查询、Mybatis整合spring、Mybatis逆向工程
		1. 学习计划 1.输入映射和输出映射 a) 输入参数映射 b) 返回值映射 2.动态sql a) If标签 b) Where标签 c) Sql片段 d) Foreach标签 3.关联查询 a) 一对 ... 
随机推荐
- 一个常用的通过curl发送HTTP请求的函数
			function: function curl_get($url, $params) { return curl_http($url, $params, 'GET'); } function curl ... 
- intellij 编译 springmvc+hibernate+spring+maven 找不到hbm.xml映射文件
			1. 错误信息 Invocation of init method failed; nested exception is org.hibernate.MappingNotFoundException ... 
- Windows 下apache https配置(phpstudy)
			1.首先获取证书,https://www.pianyissl.com/ 免费三个月的 或者 自己生成私钥.证书,然后应用到apache中. http://blog.sina.com.cn/s/blo ... 
- GitHub上一些有趣的开源项目[持续更新]
			TheAlgorithms/C-Plus-Plus 用C++实现了常见的算法,如排序算法,查找算法,以及一些常见的数据数据结构,如链表,二叉树. 链接:https://github.com/TheAl ... 
- idea控制台搜索框
			https://blog.csdn.net/honnyee/article/details/82772948 
- /etc/fstab  下的配置参数
			第一列:分区的label或者UUID 若要查看/dev/sdb1设备的label或者UUID[root@localhost ~]# dumpe2fs -h /dev/sdb1dumpe2fs 1.42 ... 
- 用java写一个死锁
			什么是死锁? 多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放.由于线程被无限期地阻塞,因此程序不可能正常终止. 不适当的使用“synchronized”关键词来管理线程对特定对象的访问 ... 
- C# List 过滤,排序,删除
			taskList_IsManager.Where(p => p.IsManager == "1").ToList(); taskList = taskList.OrderBy ... 
- 安装RabbitMQ 后配置遇到问题解决方案
			http://blog.csdn.net/j_shine/article/details/78833456 
- Gym-100923H-Por Costel and the Match(带权并查集)
			链接: https://vjudge.net/problem/Gym-100923H 题意: Oberyn Martell and Gregor Clegane are dueling in a tr ... 
