MyBatis Review——一对多关系映射配置

示例:

            查询订单表及订单明细信息。

编写sql查询语句:

SELECT
	orders.*, USER .username ,USER .sex,
	USER .address,
	orderdetail.id as orderdetail_id,
	orderdetail.items_id,
	orderdetail.items_num,
	orderdetail.orders_id
FROM
	orders,
	USER,
	orderdetail
WHERE
	orders.user_id = USER .id
	AND
  orderdetail.orders_id=orders.id

结果如下:

order定义:

resultMap配置:

<!-- 定义订单查询关联用户的resultMap -->
	<resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersUserResultMap">
		<!-- 配置映射的订单信息 -->
		<id column="id" property="id" /><!-- 订单信息的唯一标识 --><!-- 如果有多个列,组成唯一标识,配置多个id -->
		<result column="user_id" property="userId" />
		<result column="number" property="number" />
		<result column="createtime" property="createtime" />
		<result column="note" property="note" />

		<!-- 配置映射的关联的用户信息 -->
		<!-- association:用于映射关联查询单个对象的信息 property:将关联查询的用户信息映射到orders的那个属性中 -->
		<association property="user" javaType="cn.itcast.mybatis.po.User">
			<!-- 关联查询的用户的唯一标识 column:指定唯一标识用户信息的列 -->
			<id column="user_id" property="id" />
			<result column="username" property="username" />
			<result column="sex" property="sex" />
			<result column="address" property="address" />
		</association>

	</resultMap>

	<!-- 查询订单及订单明细的resultMap -->
	<!--  extends:
				使用继承就不用配置订单信息和用户信息的映射了
	-->
	<resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersAndOrderDetailResultMap" extends="OrdersUserResultMap">
		<!-- 订单信息 -->
	<!-- 	<id column="id" property="id" />订单信息的唯一标识如果有多个列,组成唯一标识,配置多个id
		<result column="user_id" property="userId" />
		<result column="number" property="number" />
		<result column="createtime" property="createtime" />
		<result column="note" property="note" />

		用户信息
		<association property="user" javaType="cn.itcast.mybatis.po.User">
			关联查询的用户的唯一标识 column:指定唯一标识用户信息的列
			<id column="user_id" property="id" />
			<result column="username" property="username" />
			<result column="sex" property="sex" />
			<result column="address" property="address" />
		</association> -->

		<!-- 明细信息 一个订单关联查询除了多条明细信息 要使用collection来进行映射 collection:实现了对关联查询到的多条记录进行映射
			property:将关联查询到的多条记录映射到cn.itcast.mybatis.po.Orders的哪个属性 ofType:要映射到集合属性中pojo的类型 -->
		<collection property="orderDetials" ofType="cn.itcast.mybatis.po.OrderDetial">
			<!-- 订单明细的唯一标识 -->
			<!-- id:订单明细的唯一标识 -->
			<id column="orderdetail_id" property="id" />
			<result column="items_id" property="itemsId"/>
			<result column="items_num" property="itemsNum"/>
			<result column="orders_id" property="ordersId"/>

		</collection>

	</resultMap>
<!-- 查询订单关联用户及订单明细 -->
	<select id="findOrdersAndOrderDetailResultMap" resultMap="OrdersAndOrderDetailResultMap">
		SELECT
		orders.*, USER .username ,USER .sex,
		USER .address,
		orderdetail.id as orderdetail_id,
		orderdetail.items_id,
		orderdetail.items_num,
		orderdetail.orders_id
		FROM
		orders,
		USER,
		orderdetail
		WHERE
		orders.user_id = USER .id
		AND
		orderdetail.orders_id=orders.id
	</select>

小结:

      1,使用collection来映射一对多中的List属性;

      2,使用extends来继承其他resultMap;

时间: 2024-09-20 04:23:48

MyBatis Review——一对多关系映射配置的相关文章

自己动手写ASP.NET ORM框架(三):关系映射配置—Table属性

在上一篇随笔中已经完成了ADO.NET操作数据库的封装,并已经支持多数据库,只需要在 配置文件中指定数据库类型即可,本节主要完成对象与数据库表的关系映射配置. 下面看表名的映射配置代码块1-1: [Table(Name="Student")] public class StudentEntity { //...........省略 } 在类上面用[Table(name = "Student")]属性来配置,表示该实体类StudentEntity与数 据库中的Stud

MyBatis review(一)——常见配置及方法

最近change a new job,复习下mybatisO(∩_∩)O~~~ 一,#{} 与 ${} #{}表示一个占位符号,通过#{}可以实现preparedStatement向占位符中设置值,自动进行java类型和jdbc类型转换,#{}可以有效防止sql注入. #{}可以接收简单类型值或pojo属性值. 如果parameterType传输单个简单类型值,#{}括号中可以是value或其它名称. ${}表示拼接sql串,通过${}可以将parameterType 传入的内容拼接在sql中且

MyBatis Review——加载mappers映射文件的三种方式

一,通过resource加载映射文件 <!-- 加载映射文件 --> <mappers> <mapper resource="sqlmap/User.xml"/> </mappers> 二,通过mapper接口加载映射文件 <!-- 加载映射文件 --> <mappers> <!-- 通过mapper接口加载映射文件 --> <!-- 遵循规范:需要将mapper接口类名与xml文件映射名称保持一

自己动手写ASP.NET ORM框架(五):关系映射配置—Column属性

这次将完成最后一个自定义属性功能Column,在讲Column实现之前先看看Student表的结构 如下: create table student ( studentid VARCHAR2(40), studentno VARCHAR2(40), name VARCHAR2(40), address VARCHAR2(40), telphone VARCHAR2(40) ) 然后来看看Column自定义属性的具体用法代码1-1: using System; using System.Data;

自己动手写ASP.NET ORM框架(四):关系映射配置—Id属性

上一篇中完成了Table自定义属性的功能,现在来完成Id,因为一张表最主要的是结构就 是表名(Table name).主键(Id).列(Column).主键生成策略. Id自定义属性的用法代码块1-1: [Table(name="Student")] public class StudentEntity { private string stuid; [Id(Name = "studentid", Strategy = GenerationType.SEQUENCE

[NHibernate]一对多关系(关联查询)

目录 写在前面 文档与系列文章 一对多查询 总结 写在前面 上篇文章介绍了nhibernate的一对多关系如何配置,以及级联删除,级联添加数据的内容.这篇文章我们将学习nhibernate中的一对多关系的关联查询.前面文章中也介绍的nhibernate的查询:HQL,条件查询,原生SQL查询. 文档与系列文章 [Nhibernate]体系结构 [NHibernate]ISessionFactory配置 [NHibernate]持久化类(Persistent Classes) [NHibernat

EF里一对一、一对多、多对多关系的配置和级联删除

原文:EF里一对一.一对多.多对多关系的配置和级联删除 本章节开始了解EF的各种关系.如果你对EF里实体间的各种关系还不是很熟悉,可以看看我的思路,能帮你更快的理解. I.实体间一对一的关系 添加一个PersonPhoto类,表示用户照片类 /// <summary> /// 用户照片类 /// </summary> public class PersonPhoto { [Key] public int PersonId { get; set; } public byte[] Ph

mybatis 逆向工程-大神指教mybatis逆向工程中 一对一,一对多关系如何生成

问题描述 大神指教mybatis逆向工程中 一对一,一对多关系如何生成 mybatis逆向工程中 一对一,一对多关系可以生成吗?如何.求教 解决方案 hibernate可以映射关系,mybatis中你在这个表要用到另一个表的数据,就是在这个表的实体在添加另一个表你要用的实体上去

hibernate中一对多关系的映射

昨天初次接触hibernate,仅仅弄懂了一对一关系的映射.今天学习了一天又有了新的收获,弄懂了一对多之间关系的映射. 一.一对多的关系映射 建立一对多关系关系的表的原则是将一的一方的主键加入到多的一方的表作为外键.这里以员工和部门为例子来演示.以前不用hibernate时建 立pojo类要在员工类Emp中加入一个属性,即部门编号deptid.使用hibernate则不同了,需要在"一"的一方类中加入一个set集合,里 面存放"多"的一方的对象.而在"多&