文档章节

Mbatis高级映射

 小小小施爷
发布于 2017/09/11 10:27
字数 894
阅读 46
收藏 1

1 一对一映射

使用resultMap映射的方式:

一对一resultMap

								<!-- 一对一映射 -->
<!-- 订单关联查询的resultMap 
	将整个结果映射到com.shi.POJO的Orders中
-->
<resultMap type="com.shi.POJO.Orders" id="ordersUserResultMap">
 <!-- 配置映射的订单信息 -->
	<!-- id:指定查询列中的唯一标识,订单信息中的唯一标识,如果有多个列组成唯一标识,配置多个id 
		column:指定查询列中的唯一标识,如果有多个列组成唯一标识,配置多个id
		property:订单信息的唯一标识 ,列所映射到orders中哪个属性
	-->
	<id column="id" property="id"/>
	<result column="user_id" property="user_id"/>
	<result column="number" property="number"/>
	<result column="createtime" property="createtime"/>
	<result column="note" property="note"/>
 <!-- 配置映射的关联的用户信息 -->
 	<!-- association:用于映射关联查询单个对象的信息
 	propety: 要将关联查选的用户信息映射到Orders中哪个属性 -->
 	<association property="user" javaType="com.shi.POJO.User">
 		<!-- id :关联查询用户的唯一标识
 		column:指定唯一标识用户信息的列
 		property:映射到user的哪个属性	-->
 		<id column="user_id" property="id"/>
 		<result column="username" property="username"/>
 		<result column="birthday" property="birthday"/>
 		<result column="sex" property="sex"/>
 		<result column="address" property="address"/>
 	</association>
</resultMap>

<select id="findOrderCastomResultMap" resultMap="ordersUserResultMap">
	SELECT orders.*,user.username,user.sex,user.birthday FROM orders,USER WHERE
	orders.user_id=user.id
</select>

对resultType 和 resultMap 的总结:

输入图片说明

2 一对多映射

使用resultMap实现一对多映射:

						<!-- ================一对多映射================ -->
	
	<!-- 一对多映射查询  查询订单 ,用户信息 及订单明细表 
	 -->
	 <!-- rusultMap配置      注意:如果上面有重复的东西 可以使用  extends="" -->
	 <resultMap type="com.shi.POJO.Orders" id="OrdersAndOrderDetailResultMap" >
<!-- 订单信息 -->
	 	<id column="id" property="id"/>
	 	<result column="user_id" property="user_id"/>
	 	<result column="number" property="number"/>
	 	<result column="createtime" property="createtime"/>
	 	<result column="note" property="note"/>
<!-- 用户信息 -->
	 	<association property="user" javaType="com.shi.POJO.User">
	 		<id column="user_id" property="id"/>
	 		<result column="username" property="username"/>
	 		<result column="birthday" property="birthday"/>
	 		<result column="sex" property="sex"/>
	 		<result column="address" property="address"/>
	 	</association>
<!-- 订单明细信息 -->
	 	<!-- 
	 		一个订单关联查询出来了多条明细,所以要使用collection进行映射
	 		collection:对查询到多条记录映射到集合对象中去
	 		property:将关联查询到的多条记录映射到该orderdetailList属性中去
	 		ofType:指定映射到list集合属性中pojo的类型
	 	 -->
	 	 <collection property="orderdetailList" ofType="com.shi.POJO.Orderdetail">
	 	 	<!-- id:订单明细表的唯一标识
	 	 	property:要将订单明细的唯一标识映射到com.shi.POJO.Orderdetail 的哪个属性 -->
	 	 	<id column="orderdetail_id" property="id"/>
	 	 	<result column="items_id" property="items_id"/>
	 	 	<result column="orders_id" property="orders_id"/>
	 	 	<result column="items_num" property="items_num"/>
	 	 </collection>
	 	
	 </resultMap>	 
	 <!-- sql语句 -->
	<select id="findOrdersAndOrderDetailResultMap" resultMap="OrdersAndOrderDetailResultMap">
		SELECT
			orders.*,
			user.username,
			user.sex,
			user.address,
			orderdetail.id orderdetail_id, <!-- 注意:这里需要collection中的id  所以 不能和上面属性冲突 -->
			orderdetail.items_id,
			orderdetail.orders_id,
			orderdetail.items_num
		FROM
			orders,
			USER,
			orderdetail
		WHERE 
			orders.user_id=user.id AND orderdetail.orders_id=orders.id
	</select>

对resultType 和 resultMap的总结:(一对多建议使用 resultMap

输入图片说明

3 多对多查询

映射思路:

输入图片说明

	
							<!-- =================多对多查询=============== -->
		<!-- 现在执行多对多查询  查询用户信息和商品信息 进行关联-->
	<!-- resultMap映射 -->
		<resultMap type="com.shi.POJO.User" id="UserAndItemsReusltMap">
			<!-- 对用户信息进行映射 -->
			<id column="user_id" property="id"/>
			<result column="username" property="username"/>
			<result column="birthday" property="birthday"/>
			<result column="sex" property="sex"/>
			<result column="address" property="address"/>
			
			<!-- 对订单进行映射   ######一对多映射######-->
			<collection property="orders" ofType="com.shi.POJO.Orders">
				<id column="id" property="id"/>
				<result column="user_id" property="user_id"/>
				<result column="number" property="number"/>
				<result column="createtime" property="createtime"/>
				<result column="note" property="note"/>
				
				<!-- 对订单细节进行映射 ######一对多映射######-->
				<collection property="orderdetailList" ofType="com.shi.POJO.Orderdetail">
					<id column="" property=""/>
					<result column="orderdetail_id" property="id"/>
					<result column="orders_id" property="orders_id"/>
					<result column="items_id" property="items_id"/>
					<result column="items_num" property="items_num"/>
					
					<!-- 对商品表进行映射  ######一对一映射###### -->
					<association property="items" javaType="com.shi.POJO.Items">
						<id column="items_id" property="id"/>
						<result column="items_name" property="name"/>
						<result column="items_price" property="price"/>
					</association>
				</collection>
			</collection>
		</resultMap>
	<!-- sql语句 -->
	<select id="findUserAndItemsReusltMap" resultMap="UserAndItemsReusltMap">
		SELECT 
			orders.*,
			user.username,
			user.sex,
			user.address,
			orderdetail.id orderdetail_id,
			orderdetail.items_id,
			orderdetail.orders_id,
			orderdetail.items_num,
			items.name items_name,
			items.price items_price
		FROM
			orders,
			USER,
			orderdetail,
			items
		WHERE 
			orders.user_id=user.id AND orderdetail.orders_id=orders.id AND orderdetail.items_id=items.id
		
	</select>

总结:

输入图片说明

© 著作权归作者所有

共有 人打赏支持
上一篇: mybatis的延迟加载
下一篇: 数据库模型分析
粉丝 5
博文 145
码字总数 102480
作品 0
合肥
私信 提问
Mybatis: sql中if 判断的坑

“原创精选,转载注明出处,三克油” 前言 Mbatis 的script标签可以支持很多动态SQL查询、在使用if test判断的时候、会有一些意向不到的坑 正文 我们一般在Mbatis中做update更新时、都会加上...

一朝一夕
2016/11/24
0
0
mybatis拦截器能否跳过sql的db执行逻辑

业务中需要使用sql语句语法,但是最终不会在db上去执行,需要执行其它的特殊逻辑。但是想使用mbatis的那套sql接口方式来管理sql语句。 所有是否可以通过拦截器在拿到完整的sql语句之后跳过默...

yinshuang100
2015/08/23
307
1
mybatis传入参数为0被误认为是空字符串的解决方法

在mbatis中使用Xml配置sql语句时,出现了这样一个问题。当我传入的参数为0去做判断时,mybatis会把参数0当成是空字符串去判断而引起查询结果错误。下面是我之前配置的sql语句: <if test="ov...

码代码的小司机
2018/11/19
0
0
Mybatis Plus 2.0 Beta 发布,支持 ActiveRecord

Mybatis-Plus是一款MyBatis的增强 crud 工具包,简化 增 删 改 查 操作。启动加载 XML 配置时注入单表 SQL 操作 ,为简化开发工作、提高生产率而生。Mybatis-Plus 启动注入非拦截实现、性能更...

青苗
2016/11/07
4.1K
22
spring和mbatis的配置问题

我用的是eclipse spring版本是3.2.4 mybatis3.2.2 8.1的操作系统 这我的是spring的配置文件 下面是报错信息 求帮我看看 困扰了好久了 userService的有一个唯一的实现类 实现类上面已经 注解了...

Jian~
2015/02/02
663
4

没有更多内容

加载失败,请刷新页面

加载更多

js 写文件

//写文件function doSave(value, type, name) {    var blob;    if (typeof window.Blob == "function") {        blob = new Blob([value], {type: type});    }......

重城重楼
14分钟前
1
0
Ubuntu and Apache 搭建 Let's Encrypt SSL Https

本文参考来着来自https://www.howtoing.com/install-free-lets-encrypt-ssl-certificate-for-apache-on-debian-and-ubuntu 感谢作者的分享 本事例环境介绍 ubuntu (Version 16.04.1 LTS) ubu......

罗培海
18分钟前
8
0
如何优雅的使用RabbitMQ

目录 RabbitMQ无疑是目前最流行的消息队列之一,对各种语言环境的支持也很丰富,作为一个.NET developer有必要学习和了解这一工具。消息队列的使用场景大概有3种: 1、系统集成,分布式系统的...

编程SHA
20分钟前
1
0
阿里开发者们的第19个感悟:Simple is better.

1月16日,Simple is better.这是我们送给开发者的第19个感悟。 Mars,基于矩阵的统一计算框架。已经开源。那么:Mars 是什么,能做什么,怎么做的;Mars 如何分布式地执行等。可以与继盛多交...

阿里云官方博客
21分钟前
2
0
StringBuffer 和 StringBuilder 的 3 个区别

StringBuffer 和 StringBuilder 它们都是可变的字符串,不过它们之间的区别是 Java 初中级面试出现几率十分高的一道题。这么简单的一道题,栈长在最近的面试过程中,却经常遇到很多求职者说反...

Java技术栈
25分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部