mybatis_SQL映射(3)
文章摘录自:http://blog.csdn.net/y172158950/article/details/17304645
1. 表关联
a) 嵌套查询(传说中的1+N问题)
- <resultMap id="userResult3" type="User">
- <association property="role" column="role_id" javaType="Role" select="selectRole"/>
- </resultMap>
- <select id="selectUser2" parameterType="int" resultMap="userResult3">
- select _id id, _name name, _password password, _role_id role_id from _user where _id = #{id};
- </select>
- <select id="selectRole" parameterType="int" resultType="Role">
- select _id id, _name name, _grade grade from _role where _id = #{id};
- </select>
i. 是role_id[sleect结果集column别名],不是_role_id[_user表column]。
b) 嵌套结果
- <resultMap id="userResult" type="User">
- <constructor>
- <idArg column="u_id" javaType="int"/>
- </constructor>
- <result property="name" column="u_name" />
- <result property="password" column="u_password" />
- <association property="role" column="r_id" javaType="Role">
- <id property="id" column="r_id"/>
- <result property="name" column="r_name"/>
- <result property="grade" column="r_grade"/>
- </association>
- </resultMap>
- <select id="selectUser" parameterType="int" resultMap="userResult">
- select u._id u_id, u._name u_name, u._password u_password,
- r._id r_id, r._name r_name, r._grade r_grade from _user u
- left join _role r on u._role_id=r._id where u._id =#{id};
- </select>
i. 别名的意义:每个字段名称必须唯一,重名的情况会照成错误的返回。[太土了]
ii.蛋疼的构造方法:<constructor>定义了javabean的构造方法
- public User(Integer id) { //此处必须写Integer,写int报错
- this.id = id;
- }
iii. 另外一种写法:resultMap的重用
- <resultMap id="userResult" type="User">
- <constructor>
- <idArg column="u_id" javaType="int"/>
- </constructor>
- <result property="name" column="u_name" />
- <result property="password" column="u_password" />
- <association property="role" column="r_id" resultMap="roleResult">
- </association>
- </resultMap>
- <resultMap id="roleResult" type="Role">
- <id property="id" column="r_id" />
- <result property="name" column="r_name"/>
- <result property="grade" column="r_grade"/>
- </resultMap>
2. 集合的用法
- <select id="selectUser4" parameterType="int" resultType="User">
- select _id id, _name name, _password password, _role_id role_id from _user where _role_id = #{id};
- </select>
- <select id="selectRole4" parameterType="int" resultMap="selectRole4">
- select _id id, _name name, _grade grade from _role where _id = #{id};
- </select>
- <resultMap id="selectRole4" type="Role">
- <collection property="users" column="id" ofType="User" select="selectUser4"/>
- </resultMap>
i. 仍要注意,resultMap中column都是查询结果集的别名
mybatis_SQL映射(3)的更多相关文章
- mybatis_SQL映射(4)鉴别器
摘录自:http://blog.csdn.net/y172158950/article/details/17505739 鉴别器:有时一个单独的数据库查询也许返回很多不同(但是希望有些关联)数据类型的 ...
- mybatis_SQL映射(1)
文章摘录自:http://blog.csdn.net/y172158950/article/details/17258377 1. select的映射 <select id="sele ...
- mybatis_SQL映射(2)
文章摘录自:http://blog.csdn.net/y172158950/article/details/17258377 1. sql的重用:定义一个sql片段,可在任何SQL语句中重用该片段. ...
- Hibernatel框架关联映射
Hibernatel框架关联映射 Hibernate程序执行流程: 1.集合映射 需求:网络购物时,用户购买商品,填写地址 每个用户会有不确定的地址数目,或者只有一个或者有很多.这个时候不能把每条地址 ...
- hibernate多对多关联映射
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- Dapper逆天入门~强类型,动态类型,多映射,多返回值,增删改查+存储过程+事物案例演示
Dapper的牛逼就不扯蛋了,答应群友做个入门Demo的,现有园友需要,那么公开分享一下: 完整Demo:http://pan.baidu.com/s/1i3TcEzj 注 意 事 项:http:// ...
- ElasticSearch 5学习(9)——映射和分析(string类型废弃)
在ElasticSearch中,存入文档的内容类似于传统数据每个字段一样,都会有一个指定的属性,为了能够把日期字段处理成日期,把数字字段处理成数字,把字符串字段处理成字符串值,Elasticsearc ...
- .NET平台开源项目速览(14)最快的对象映射组件Tiny Mapper
好久没有写文章,工作甚忙,但每日还是关注.NET领域的开源项目.五一休息,放松了一下之后,今天就给大家介绍一个轻量级的对象映射工具Tiny Mapper:号称是.NET平台最快的对象映射组件.那就一起 ...
- ASP.NET Core的路由[1]:注册URL模式与HttpHandler的映射关系
ASP.NET Core的路由是通过一个类型为RouterMiddleware的中间件来实现的.如果我们将最终处理HTTP请求的组件称为HttpHandler,那么RouterMiddleware中间 ...
随机推荐
- [Android游戏开发]游戏框架的搭建
通常情况下,游戏开发的基本框架中,一般包括以下模块: 窗口管理(Window management):该模块负责在Android平台上创建.运行.暂停.恢复游戏界面等功能. 输入模块(Input):该 ...
- java 集合类基础问题汇总
1.Java集合类框架的基本接口有哪些? 参考答案 集合类接口指定了一组叫做元素的对象.集合类接口的每一种具体的实现类都可以选择以它自己的方式对元素进行保存和排序.有的集合类允许重复的键,有些不允许 ...
- 从JVM字节码执行看重载和重写
Java 重写(Override)与重载(Overload) 重写(Override) 重写是子类对父类的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变.即外壳不变,核心重写! 重写的 ...
- swiper轮播问题之二:默认显示3张图片,中间显示全部两边显示部分
其二:项目遇到比较有点要求的轮播图,默认显示3张图片,中间显示全部,两边显示部分.如图: 网上找了也没有找到合适的,最后经过自己摸索写了出来,贴出代码分享给大家. CSS .swipe ...
- sed中引用变量
sed 中引用变量 eval sed 's/string/$REPLACE/g' file awk 中引用变量 awk 在匹配字符串的时候,有时候需要需要引用变量. $pid= eval " ...
- html5 storage事件
HTML5 虽然很多年了,但是真的了解不不够不够.主题说的是 storage时间,说起对 storage 事件的了解还是从 QQ音乐 说起. QQ音乐的主页是 https://y.qq.com , 而 ...
- jquery tips简易使用方法 新手必看
使用jquery1.12.4以上版本 使用jquery插件 tips .beg-pull-right 点击时的选择器 在这里写的是一个类选择器 记得引入jquery $(".beg-pu ...
- RESTful 的总结
1.什么是RESTful? REST,即Representational State Transfer的缩写."(资源的)表现层状态转化". 2.什么是表现层? "资源& ...
- JAVA处理Http请求(GET,POST)
本文用的是java.net里面的方法,HttpClient也可以. java.net.HttpURLConnection java.net.URL 1. GET public static Strin ...
- [转载]Tortoise SVN使用方法,简易图解
刚到公司实习,为了版本控制,我公司使用SVN控制版本,在此记下SVN使用方法,仅供参考! 废话少说,上图! ---------------------------------- ...