MyBatis的关联映射

一、概述

在关系型数据库中,多表之间存在着三种关联关系,分别为一对一、一对多和多对多。

这三种关联关系的具体说明如下。

●一对一:在任意一方引入对方主键作为外键。

●一对多:在"多"的一方,添加"一"的一方的主键作为外键。

●多对多:产生中间关系表,引入两张表的主键作为外键,两个主键成为联合主键或使用新

的字段作为主键。

通过数据库中的表可以描述数据之间的关系,同样,在Java中,通过对象也可以进行关系

描述,如图所示。

在图中,关系的描述:

  • 一对一的关系:就是在本类中定义对方类型的对象,如A类中定义B类类型的属性b,B类中定义A类类型的属性a。
  • 一对多的关系:就是一个A类类型对应多个B类类型的情况,需要在A类中以集合的方式引入B类类型的对象,在B类中定义A类类型的属性a。
  • 多对多的关系:在A类中定义B类类型的集合,在B类中定义A类类型的集合。

二、一对多

与一对一的关联关系相比,开发人员接触更多的关联关系是一对多( 或多对一)。例如一个用户可以有多个订单,同时多个订单归一个用户所有。用户和订单的关联关系如图所示。那么使用MyBatis 是怎么处理这种一对多关联关系的呢?我们需要借助<resultMap>元素,它包含了一个<collection>子元素, MyBatis就是通过该元素来处理一对多关联关系的。<collection> 子元素的属性大部分与<association>元素相同,但其还包含一个特殊属性一ofType。ofType 属性与javaType属性对应,它用于指定实体对象中集合类属性所包含的元素类型。

<collection>元素的使用也非常简单,同样可以参考如下两种示例进行配置,具体代码如下。

复制代码
<!--方式一:嵌套查询-->
<collection property="ordersList" column="id" ofType="com. itheima. po. Orders "
   select="com. itheima.mapper.OrdersMapper. selectOrders"/>
<!--方式二:嵌套结果-->
<collection property="ordersList" ofType=" com.itheima.po.Orders">
   <id property="id" column="orders id" />
   <result property= " number" column=" number" />
</collection>

三、例子

现有商品表和商品类别表,如图所示。

我们先在数据库中创建两张表,接着创建他们的持久化类(set,get,toString)。然后我们创建映射文件,最后编写测试类。

映射文件:

复制代码
  <!-- namespace表示命名空间-->
  <mapper namespace="com.qcby.mapper.ProductMapper">
  
  <!--一对多:查看某一商品及其关联的类别信息。注意:当关联查询出的列名相同,则需要使用别名区分-->
	<select id="findProductWithCategory" parameterType="String"  resultMap="ProductWithCategoryResult">
		select product.* 
		from product,category 
		where product.typeid=category.id 
		and category.typename =#{typename}
	</select>
	<resultMap type="com.qcby.po.Product" id="ProductWithCategoryResult">
		<id property="id" column="id"/>
		<result property="goodsname" column= "goodsname"/>
		<result property="price" column="price"/>
		<result property="typeid" column="typeid"/>
		<!--一对多关联映射: collectionofType表示属性集合中元素的类型,List<Category>属性即Category类-->
		<collection property="cList" ofType ="com.qcby.po.Category">
			<id property="id" column="id"/>
			<result property="typename" column="typename"/>
		</collection>
    </resultMap>
   </mapper>

在映射文件中,我们使用了MyBatis嵌套结果的方式定义了一个根据商品类别查询商品信息的select语句。因为返回的用户对象中,包含Category集合对象属性,所以需要手动编写结果映射信息。

测试类:

复制代码
@Test
	public void findProductTest() {
		//1、生成sqlsession对象
		SqlSession sqlSession = MybatisUtils.getSession();
		//2、查询类别为白色家电的商品
		String typename = "黑色家电";
		List<Product> product = sqlSession.selectList("com.qcby.mapper.ProductMapper.findProductWithCategory", typename);
		//3、输出查询结果
		for (Product product2 : product) {
			  System.out.println("商品ID: " + product2.getId());
			  System.out.println("商品名称: " + product2.getGoodsname());
			  System.out.println("商品价格: " + product2.getPrice());
			  System.out.println("商品类别ID: " + product2.getTypeid());
		}
		//4、提交事务
		sqlSession.commit();
		//5、关闭sqlsession
		sqlSession.close();
	}
相关推荐
孤廖3 小时前
吃透 C++ 栈和队列:stack/queue/priority_queue 用法 + 模拟 + STL 标准实现对比
java·开发语言·数据结构·c++·人工智能·深度学习·算法
我命由我123453 小时前
Android 对话框 - 对话框全屏显示(设置 Window 属性、使用自定义样式、继承 DialogFragment 实现、继承 Dialog 实现)
android·java·java-ee·android studio·android jetpack·android-studio·android runtime
Full Stack Developme3 小时前
java.net 包详解
java·python·.net
一叶飘零_sweeeet4 小时前
深入 Spring 内核:解密 15 种设计模式的实战应用与底层实现
java·spring·设计模式
凤山老林4 小时前
排序算法:详解插入排序
java·开发语言·后端·算法·排序算法
彦楠4 小时前
IDEA实用快捷键
java·ide·intellij-idea
豆沙沙包?4 小时前
2025年--Lc197-077. 排序链表(链表,尾插法)--Java版
java·数据结构·链表
m0_651593914 小时前
深入理解软件设计中的协议与规范:从理论到Java实践
java·软件工程·代码规范·设计规范
Knight_AL4 小时前
Tomcat 类加载器隔离机制的实际应用
java·tomcat
FreeBuf_4 小时前
Spring两大漏洞可导致泄露敏感信息及安全防护绕过(CVE-2025-41253/41254)
java·安全·spring