Mybatis进阶学习笔记——关系查询——一对一查询
用户和订单的需求
通过查询订单,查询用户,就是一对一查询
(1)自定义JavaBean(常用,推荐使用)
- <select id="queryOrderUser" resultType="OrderUser">
- SELECT o.id,o.user_id,u.name,o.productname
- FROM t_order o LEFT JOIN t_user u ON o.user_id= u.id
- </select>
OrderUser.java:
- package cn.sm1234.domain;
- public class OrderUser extends Order {
- //Order中没有name
- private String name;
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- }
- @Test
- public void test1() {
- SqlSession sqlSession = SessionUtils.getSession();
- // getMapper(): 返回指定接口的动态代理的实现类对象
- OrderDao dao = sqlSession.getMapper(OrderDao.class);
- List<OrderUser> list = dao.queryOrderUser();
- for (OrderUser orderUser : list) {
- System.out.println(orderUser.getName()+"-"+orderUser.getProductname());
- }
- sqlSession.commit();
- sqlSession.close();
- }
OrderDao.java:
- public interface OrderDao {
- /**
- * 查询订单,并且关联查询用户信息
- */
- public List<OrderUser> queryOrderUser();
- }
(2)ResultMap封装
- <!-- type="实体类" -->
- <resultMap type="Order" id="OrderUserResultMap">
- <id column="id" property="id"/>
- <result column="productname" property="productname"/>
- <result column="orderno" property="orderno"/>
- <!-- user_id封装到User中 -->
- <!-- 关联属性
- property:关联属性名称(Order类中的user)
- javaType:类型(User (即User user))
- -->
- <association property="user" javaType="User">
- <!-- column中的字段名称应该为当前查询结果的字段名称 -->
- <id column="user_id" property="id"/>
- <result column="name" property="name"/>
- <result column="password" property="password"/>
- </association>
- </resultMap>
- <select id="queryOrderUserResultMap" resultMap="OrderUserResultMap">
- SELECT o.id,o.user_id,u.name,o.productname
- FROM t_order o LEFT JOIN t_user u ON o.user_id= u.id
- </select>
Order.java:
- package cn.sm1234.domain;
- public class Order {
- private Integer id;
- private String productname;
- private String orderno;
- private Integer userId;
- private User user;
- public Integer getId() {
- return id;
- }
- public void setId(Integer id) {
- this.id = id;
- }
- public String getProductname() {
- return productname;
- }
- public void setProductname(String productname) {
- this.productname = productname;
- }
- public String getOrderno() {
- return orderno;
- }
- public void setOrderno(String orderno) {
- this.orderno = orderno;
- }
- public Integer getUserId() {
- return userId;
- }
- public void setUserId(Integer userId) {
- this.userId = userId;
- }
- public User getUser() {
- return user;
- }
- public void setUser(User user) {
- this.user = user;
- }
- }
- /**
- * 查询订单,查询用户(ResultMap)
- * @return
- */
- public List<Order> queryOrderUserResultMap();
- @Test
- public void test2() {
- SqlSession sqlSession = SessionUtils.getSession();
- // getMapper(): 返回指定接口的动态代理的实现类对象
- OrderDao dao = sqlSession.getMapper(OrderDao.class);
- List<Order> list = dao.queryOrderUserResultMap();
- for (Order order : list) {
- System.out.println(order.getProductname()+"-"+order.getUser().getName());
- }
- sqlSession.commit();
- sqlSession.close();
- }
Mybatis进阶学习笔记——关系查询——一对一查询的更多相关文章
- Mybatis进阶学习笔记——关系查询——一对多查询
一个客户拥有多个订单 <resultMap type="User" id="UserOrderResultMap"> <id column=& ...
- Mybatis进阶学习笔记——动态代理方式开发Dao接口、Dao层(推荐第二种)
1.原始方法开发Dao Dao接口 package cn.sm1234.dao; import java.util.List; import cn.sm1234.domain.Customer; pu ...
- Mybatis进阶学习笔记——动态sql
1.if标签 <select id="queryByNameAndTelephone" parameterType="Customer" resultTy ...
- Mybatis进阶学习笔记——输出映射
输出映射(例如一个方法的返回至使用什么类型去接收) 1.基本类型 <!-- 统计记录数 --> <select id="queryTotalCount" resu ...
- Mybatis进阶学习笔记——输入映射
1.输入映射 输入映射支持的类型: 1) 基本的类型,int,String,double 等(*)2) JavaBean 类型(*)3) 包装JavaBean 类型(对象里面包含另一个对象) 1.1基 ...
- IBatis.Net学习笔记六--再谈查询
在IBatis.Net学习笔记五--常用的查询方式 中我提到了一些IBatis.Net中的查询,特别是配置文件的写法. 后来通过大家的讨论,特别是Anders Cui 的提醒,又发现了其他的多表查询的 ...
- SQL反模式学习笔记18 减少SQL查询数据,避免使用一条SQL语句解决复杂问题
目标:减少SQL查询数据,避免使用一条SQL语句解决复杂问题 反模式:视图使用一步操作,单个SQL语句解决复杂问题 使用一个查询来获得所有结果的最常见后果就是产生了一个笛卡尔积.导致查询性能降低. 如 ...
- 数据库学习笔记3 基本的查询流 2 select lastname+','+firstname as fullname order by lastname+','+firstname len() left() stuff() percent , select top(3) with ties
数据库学习笔记3 基本的查询流 2 order by子句对查询结果集进行排序 多列和拼接 多列的方式就很简单了 select firstname,lastname from person.pers ...
- 爱了!阿里大神最佳总结“Flutter进阶学习笔记”,理论与实战
前言 "小步快跑.快速迭代"的开发大环境下,"一套代码.多端运行"是很多开发团队的梦想,美团也一样.他们做了很多跨平台开发框架的尝试:React Native. ...
随机推荐
- git命令行界面
学习目标:掌握git命令行界面的操作.掌握最基本的clone add commit push pull操作. 先下载客户端:http://github-windows.s3.amazonaws.com ...
- 架构师成长之路7.1 CDN理论
点击返回架构师成长之路 架构师成长之路7.1 CDN理论 CDN,Content Distribute Network,内容分发网络:CDN解决的是如何将数据快速可靠从源站传递到用户的问题.用户获取数 ...
- BroadcastReceiver 接收系统短信广播
BroadcastReceiver 接收系统短信广播 /* 注册广播: * |--静态注册 (在AndroidManifest .xml 中注册) * <receiver androi ...
- [luogu4513]小白逛公园
题目描述 在小新家附近有一条"公园路",路的一边从南到北依次排着n个公园,小白早就看花了眼,自己也不清楚该去哪些公园玩了. 一开始,小白就根据公园的风景给每个公园打了分-.-.小新 ...
- 清理SharePoint 2013 安装配置环境
最近我们在做Farm Building时,经常要清理Sharepoint的环境,简单整理了下清理步骤: 1. Delete web app 2. Delete servic ...
- 洛谷 P1110 [ZJOI2007]报表统计 解题报告
P1110 [ZJOI2007]报表统计 题目描述 \(Q\)的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小\(Q\)希望可以帮妈妈分担一些工作,作为她的生日礼物之一. 经过仔细 ...
- luogu4197 Peaks (kruskal重构树+主席树)
按照边权排序建出kruskal重构树,每次就变成了先找一个权值<=x的最远的祖先,然后看这个子树的第k小.离散化一下,在dfs序上做主席树即可 而且只需要建叶节点的主席树 注意输出的是第k小点的 ...
- [POI2010]KLO-Blocks——一道值得思考的题
题目大意: 给出N个正整数a[1..N],再给出一个正整数k,现在可以进行如下操作:每次选择一个大于k的正整数a[i],将a[i]减去1,选择a[i-1]或a[i+1]中的一个加上1.经过一定次数的操 ...
- js(=>) 箭头函数 详细解说 案例大全
ES6标准新增了一种新的函数:Arrow Function(箭头函数). 为什么叫Arrow Function?因为它的定义用的就是一个箭头: x => x * x 上面的箭头函数相当于: fu ...
- VBScript入门篇
VBScript入门篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.定义一个过程 定义一个过程:可以将相同的操作的代码提取出来,方便其他人来调用这段代码,可以减少你的代码的重 ...