mybatis关联查询

关联查询

一对一
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.woniuxy.dao.EmpDao">
  <!--一步查询-->
	<select id="selectEmpByEid" resultMap="empmapper">
		SELECT * FROM dep d ,emp e WHERE d.did=e.did AND eid=#{eid}
	</select>
	
	<resultMap type="Emp" id="empmapper">
		<id column="eid" property="eid"/>
		<result column="ename" property="ename"/>
		对一
		<association property="dep" javaType="Dep">
			<id column="did" property="did"/>
			<result column="dname" property="dname"/>
		</association>
	</resultMap>
	
	
	<select id="selectAllEmps" resultMap="empmapper">
		SELECT * FROM dep d ,emp e WHERE d.did=e.did 
	</select>
	
<!--多步查询-->
	<select id="selectEmpByEid" resultMap="empmapper">
		SELECT * FROM emp WHERE eid=#{eid}
	</select>
	
	<resultMap type="Emp" id="empmapper">
		<id column="eid" property="eid"/>
		<result column="ename" property="ename"/>
		<association property="dep" javaType="Dep" select="selectDepByDid" column="did" />
	</resultMap>
	
	<select id="selectDepByDid" resultType="Dep">
		SELECT * FROM dep WHERE did=#{did}
	</select>
	
	
	<select id="selectAllEmps" resultMap="empmapper">
		SELECT * FROM emp 
	</select>
</mapper>
一对多

实体类

public class Dep {

	private Integer did;
	private String dname;
	//查询部门的时候,要求同时展示部门中的所有员工信息
	//一对多:一个部门有多个员工
	//不用可以不写
	private List<Emp> emps;

    
public class Emp {

	private Integer eid;
	private String ename;
	//一个员工属于一个部门,展示员工的时候同时展示这个员工的部门信息
	//(多对一)一对一
	//外键列在实体类中一般都写成对象,不用可以不查
	private Dep dep;

Dao

package com.woniuxy.dao;

import com.woniuxy.entity.Dep;

public interface DepDao {

	Dep selectDepByDid(int did);
}

映射文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.woniuxy.dao.DepDao">

	<!-- 使用连接一次出查询,使用resultMap:指定如何将查询的数据装换成想要的类型 -->
	<select id="selectDepByDid" resultMap="depmapper">
		SELECT * FROM dep d,emp e WHERE d.did=e.did AND d.did=#{did}
	</select>
	
	<!-- type:转换的类型 -->
	<resultMap type="Dep" id="depmapper">
		<id  column="did" property="did"/>
		<result  column="dname" property="dname"/>
		<!-- 一对多的映射关系通过collection标签匹配
			property:dep对象中哪个属性是集合
			ofType:集合属性的元素类型
		 -->
		<collection property="emps" ofType="Emp">
			<id column="eid" property="eid"/>
			<result column="ename" property="ename"/>
		</collection>

	</resultMap>
</mapper>
多对一
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.woniuxy.dao.EmpDao">

	 <select id="selectEmpByEid" resultMap="empmapper">
		SELECT * FROM dep d ,emp e WHERE d.did=e.did AND eid=#{eid}
	</select>
	
	<resultMap type="Emp" id="empmapper">
		<id column="eid" property="eid"/>
		<result column="ename" property="ename"/>
		对一
		<association property="dep" javaType="Dep">
			<id column="did" property="did"/>
			<result column="dname" property="dname"/>
		</association>
	</resultMap>
	
	
	<select id="selectAllEmps" resultMap="empmapper">
		SELECT * FROM dep d ,emp e WHERE d.did=e.did 
	</select>
</mapper>
多对多

1.通过中间表转化为一对多和多对一

MyBatis关联查询是指在查询数据库时,通过配置映射文件,将多个表之间的关联数据查询出来并进行组合。可以使用嵌套结果映射或嵌套查询来处理关联查询。 在嵌套结果映射中,可以使用\<resultMap>来定义映射关系,并使用\<association>来设置关联对象。例如,可以定义一个resultMap来映射Classes和Teacher表之间的关联关系,然后通过联表查询将两个表的数据关联起来。 另一种方式是使用嵌套查询,即在映射文件中通过\<select>标签设置嵌套查询语句来获取关联数据。通过联表查询获取到的数据可以作为嵌套查询的参数,从而获取到关联数据。 以上就是MyBatis关联查询的基本概念和使用方式。可以根据具体的需求选择合适的方式进行关联查询操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SSM框架的学习与应用-Java EE企业级应用开发学习记录(第四天)Mybatis的关联映射和缓存机制](https://download.csdn.net/download/m0_53659738/88253127)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [mybatis关联查询](https://blog.csdn.net/faramita_of_mine/article/details/122202515)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值