MyBatis用嵌套ResultMap实现一对多映射
我的技术博客经常被流氓网站恶意爬取转载。请移步原文:http://www.cnblogs.com/hamhog/p/3959451.html,享受整齐的排版、有效的链接、正确的代码缩进、更好的阅读体验。
背景
我们知道,MyBatis可以很方便地把SQL select出来的数据直接映射为对象的属性,把对象取出来。
但是,有些对象的属性是集合类型,集合里保存的是数个其他类型的对象。如何用MyBatis把它取出来呢?
例子
以以下这个应用场景为例:一个教师对应多个课程。
数据结构如下:
public class Course{
int id;
String name;
}
public class Tutor{
int id;
String name;
List<Course> courses;
}
这时,就需要分别写出两者的ResultMap:
<resultMap type="Course" id="courseResult">
<result column="course_id" property="id" />
<result column="course_name" property="name" />
</resultMap> <resultMap type="Tutor" id="tutorResult">
<id column="tutor_id" property="id" />
<result column="tutor_name" property="name" />
<collection property="courses" resultMap="Course" />
</resultMap>
然后把select语句的resultMap设为tutorResult:
<select id="findTutorById" parameterType="int" resultMap="TutorResult">
SELECT TUTOR_ID, TUTOR_NAME, COURSE_ID, COURSE_NAME FROM TUTOR
</select>
这样就能把Tutor类的数据正确地读进来了。
实验
以上这个例子来自《Java Persistence with MyBatis3》。让我好奇的是,myBatis是如何判断,哪些course应该对应同一个tutor的呢?对于每个course,它是怎么寻找应该把它放进哪个tutor的List里呢?
用以上的例子,数据为:
| tutor_id | tutor_name | course_id | course_name |
| 1 | 张三 | 1 | 语文 |
| 2 | 李四 | 2 | 数学 |
读进来的数据是,大概是这样的:
张三 : 语文
李四 : 数学
如果我们把数据改成这样:
| tutor_id | tutor_name | course_id | course_name |
| 1 | 张三 | 1 | 语文 |
| 1 | 李四 | 2 | 数学 |
读进来的数据,就会变成这样:
张三:语文, 数学
“李四”没有了。数学归进了张三里。这是为什么呢?
原来,Tutor的ResultMap里,指定了id为tutor_id。一旦指定了id,myBatis就认定它是全局唯一的;李四的id与张三相同,因此会被认为是同一个对象,则李四的数据被直接忽略。
上面这个例子可以说明,如果有指定id,会去根据id判断是否为同一个对象。id相同,即使属性不同,还是认为是同一个对象。
而我们如果把id改为普通的result,把Tutor的ResultMap改成这样:
<resultMap type="Tutor" id="tutorResult">
<result column="tutor_id" property="id" />
<result column="tutor_name" property="name" />
<collection property="courses" resultMap="Course" />
</resultMap>
此时,仍然用刚才的数据:
| tutor_id | tutor_name | course_id | course_name |
| 1 | 张三 | 1 | 语文 |
| 1 | 李四 | 2 | 数学 |
则读进来的数据,就会变成这样了:
张三:语文
李四:数学
上面这个例子可以说明,如果没有指定id,会去根据所有属性去判断是否为同一个对象。只要有一个属性不同,就认为不是同一个对象。
如果把数据改为:
| tutor_id | tutor_name | course_id | course_name |
| 1 | 张三 | 1 | 语文 |
| 1 | 张三 | 2 | 数学 |
则读进来的数据,就会变成:
张三:语文,数学
如果所有属性都相同,就会认为是同一个对象了。
写到这里,发现思路不太清晰。其实course按照什么去找tutor,主要看的是同一行的tutor,看是这个tutor是不是新的。
MyBatis用嵌套ResultMap实现一对多映射的更多相关文章
- MyBatis - (二) 一对一映射和一对多映射
1. 一对一映射 例子表: 学生表 地址表 POJO类 public class Address { private Integer addrId; private String street; pr ...
- mybatis bug之resultmap缺少object-relation匹配参数password,造成设置密码不成功
1.mybatis bug之resultmap缺少object-relation匹配参数password,造成设置密码不成功 在resultmap里没有设置user类中password属性和数据库表t ...
- MyBatis从入门到精通(十一):MyBatis高级结果映射之一对多映射
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解MyBatis中如何使 ...
- mybatis一对一嵌套查询
要求:查询一个员工的时候,把他对应的部门也查询出来 实现(其他配置这里不作说明,框架基于spring_springMVC_mybatis_oracle): 如有不对或不适的地方,请多多指教. 1.新建 ...
- mybatis的嵌套查询(嵌套查询nested select和嵌套结果nested results查询)区别
(转自:http://blog.csdn.net/canot/article/details/51485955) Mybatis表现关联关系比hibernate简单,没有分那么细致one-to-man ...
- mybatis的嵌套查询与嵌套结果查询的不同
原文:https://blog.csdn.net/qq_39706071/article/details/85156840 实体类: 嵌套查询mapper方法:嵌套查询的弊端:即嵌套查询的N+1问题尽 ...
- mybatis中的resultMap
resultMap <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBL ...
- Mybatis 入门之resultMap与resultType解说实例
resultMap:适合使用返回值是自己定义实体类的情况 resultType:适合使用返回值得数据类型是非自己定义的,即jdk的提供的类型 resultMap : type:映射实体类的数据类型 i ...
- Mybatis复杂嵌套关联一例
Mybatis three entity relation:association in collection PatentMapper.xml <resultMap id="Bas ...
随机推荐
- MySQL Order By实现原理分析和Filesort优化
http://blog.csdn.net/hguisu/article/category/796963
- LINUX CACHE IO THREAD
http://www.penglixun.com/tech/system/linux_cache_discovery.html http://my.oschina.net/HardySimpson/b ...
- JqGrid TreeView使用
1.前端 <script src="@Url.Content("~/Scripts/jquery/jquery-1.9.0.min.js")" type= ...
- LeetCode3 Longest Substring Without Repeating Characters
题意: Given a string, find the length of the longest substring without repeating characters. Examples: ...
- .net中的多线程
一.多线程的概念 什么是进程呢?当一个程序开始运行时,它就是一个进程,进程所指包括运行中的程序和程序所使用到的内存和系统资源.而一个进程又是由多个线程所组成的,线程是程序中的一个执行流, ...
- hadoop下的Pipes(用C++进行hadoop程序开发)
说明:这篇博客来自我的CSDN博客:http://blog.csdn.net/lxxgreat/article/details/7755369 经过一上午的努力,终于以伪分布式模式运行了C++版的Ma ...
- Sql Server触发器案例(初学者学习案例)
万事都是从最简单的一句“hello world”开始,所以我接下里介绍的sql触发器学习案例也从最简单的案例来说明分析: 1.首先创建表,这几张表你们也许很熟,在百度搜触发器案例都是使用这2张表 Cr ...
- Jquery插件(CKEditor)
描述 在html页面实现像word一样的编辑功能(可视化HTML编辑器) 解决方法 ckeditor插件官方网站 http://ckeditor.com/ 使用 1:去官方下载ckeditor插件,添 ...
- WPF 之 数据绑定
数据绑定需要: 后台必须要有与控件对应的类和相关的属性 在后台new 一个类的对象 在后台把控件的数据上下文设置为该对象. 在XAML中把要绑定的控件中Text = "{Bindi ...
- (转载)一步一步学Linq to sql系列文章
现在Linq to sql的资料还不是很多,本人水平有限,如果有错或者误导请指出,谢谢. 一步一步学Linq to sql(一):预备知识 一步一步学Linq to sql(二):DataContex ...