MyBatis:学习笔记(3)——关联查询

MyBatis:学习笔记(3)——关联查询

关联查询

理解联结

  SQL最强大的功能之一在于我们可以在数据查询的执行中可以使用联结,来将多个表中的数据作为整体进行筛选

  模拟一个简单的在线商品购物系统,如果我们将用户信息和订单信息都保存在user表中,这样就不存在联结关系,因为我们仅仅操作一张表就好

  但是这是非常不明智的选择,举例来说,一个用户可以拥有多个订单,如果保存在一个表中,势必会导致用户信息的多次出现,因为每个订单绑定的用户信息都是相同的。

  所以我们尽量要将不同的信息存储与不同的表中,但是单单像下面这样,数据相互独立,查询将会更加不便。

    

  所以,我们在创建表的时候就应该为联结准备条件,像下面这样,这样我们就在形式上创建了一种关联关系

    

创建联结

  我们只是为了解释和引入关联的概念,就简单实现关联的SQL语句

    

  结果如图所示

    

一对一查询

使用ResultType

  1.需求

    为了更好的理解一对一查询,我们设计如下需求:查询订单信息,并关联查询创建该订单的用户信息。

  2.SQL语句:

    

  3.POJO:

   

说明:

  将上边SQL查询的结果集映射到POJO中, 所以该POJO必须包含所有的查询列名。但是原始的Orders.java不能映射全部字段,需要新创建或者扩展原始的POJO,来包含所有的查询列。

4.编写映射文件:Mapper.xml

          

  5.使用动态代理的方法

    

  6.测试

    

使用resultMap

  1.需求

    为了更好的理解一对一查询,我们设计如下需求:查询订单信息,并关联查询创建该订单的用户信息。

  2.SQL语句:

    

  3.直接映射到Order对象中

    

  说明:

    使用resultMap将查询结果中的订单信息映射到Orders对象中,在Orders类中添加user属性,将关联查询到的用户信息映射到Orders对象中的user属性中。

  4.定义ResultMap

     

  5.定义StateMent

    

  6.测试

    

一对多查询

  1.需求

    为了更好的理解一对多查询,我们设计如下需求:查询订单信息,并关联查询创建该订单的订单明细信息。

  2.SQL语句    

    

  3.直接映射到Order对象中

    

  4.resultMap的定义

    

  说明

    collection中,要使用ofType属性,表示list集合属性中的POJO类型。  

  5.定义StateMent

    

  6.测试

    Orders{id=3, userId=1, number=‘1000010‘, createtime=Wed Feb 04 13:22:35 CST 2015, note=‘null‘, user=User{id=1, username=‘王五‘, sex=‘2‘, birthday=null, address=‘null‘}, details=[OrderDetail{id=1, orders_id=null, items_id=1, items_num=1}, OrderDetail{id=2, orders_id=null, items_id=2, items_num=3}]}
    Orders{id=4, userId=1, number=‘1000011‘, createtime=Tue Feb 03 13:22:41 CST 2015, note=‘null‘, user=User{id=1, username=‘王五‘, sex=‘2‘, birthday=null, address=‘null‘}, details=[OrderDetail{id=3, orders_id=null, items_id=3, items_num=4}, OrderDetail{id=4, orders_id=null, items_id=2, items_num=3}]}

总结

  resultMap与resultType的区别:点击查看  

  

  

时间: 2024-10-12 08:05:38

MyBatis:学习笔记(3)——关联查询的相关文章

mybatis学习笔记(10)-一对一查询

mybatis学习笔记(10)-一对一查询 mybatis学习笔记10-一对一查询 resultType实现 resultMap实现 resultType和resultMap实现一对一查询小结 本文使用两种方式(resultType和resultMap)实现一对一查询,查询订单信息,关联查询创建订单的用户信息 resultType实现 sql语句 确定查询的主表:订单表 确定查询的关联表:用户表 关联查询使用内连接?还是外连接? 因为orders表中有一个外键(user_id),通过外键关联查询

Mybatis学习笔记-一对一关联

Teacher.java实体类 . 对应数据库teacher表 public class Teacher { private int id; private String name; //... } Classes.java实体类 . 对应数据库class表 public class Classes { private int id; private String name; private Teacher teacher; //... } 第一种方式 <!--  方式一:嵌套结果:使用嵌套结果

springmvc+mybatis学习笔记(汇总)

springmvc+mybatis学习笔记(汇总) 标签 : springmvc mybaits springmvcmybatis学习笔记汇总 目录 联系作者 笔记分为两大部分:mybatis和springmvc mybatis springmvc 笔记内容主要是mybatis和springmvc的一些基本概念和使用方法,涉及概念介绍.环境搭建.编程细节.运行调试等方面. 这套笔记整体偏入门和应用,适合快速上手,对底层实现和机理并未做过多分析.我后续会研读spring源码,并把学习的收获写成博客

mybatis学习笔记(11)-多对多查询

mybatis学习笔记(11)-多对多查询 mybatis学习笔记11-多对多查询 示例 多对多查询总结 resultMap总结 本文实现多对多查询,查询用户及用户购买商品信息. 示例 查询主表是:用户表 关联表:由于用户和商品没有直接关联,通过订单和订单明细进行关联,所以关联表:orders.orderdetail.items sql SELECT orders.*, user.username, user.sex, user.address, orderdetail.id orderdeta

mybatis学习笔记(11)-一对多查询

mybatis学习笔记(11)-一对多查询 mybatis学习笔记11-一对多查询 示例 小结 本文实现一对多查询,查询订单及订单明细的信息 示例 sql 确定主查询表:订单表 确定关联查询表:订单明细表 在一对一查询基础上添加订单明细表关联即可. SELECT orders.*, user.username, user.sex, user.address, orderdetail.id orderdetail_id, orderdetail.items_id, orderdetail.item

mybatis学习笔记(13)-查询缓存之二级缓存

mybatis学习笔记(13)-查询缓存之二级缓存 mybatis学习笔记13-查询缓存之二级缓存 二级缓存原理 开启二级缓存 调用pojo类实现序列化接口 测试方法 useCache配置 刷新缓存就是清空缓存 应用场景和局限性 本文主要讲mybatis的二级缓存,二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的. 二级缓存原理 首先开启mybatis的二级缓存. sqlS

mybatis学习笔记(14)-查询缓存之中的一个级缓存

mybatis学习笔记(14)-查询缓存之中的一个级缓存 mybatis学习笔记14-查询缓存之中的一个级缓存 查询缓存 一级缓存 一级缓存工作原理 一级缓存測试 一级缓存应用 本文主要讲mybatis的一级缓存.一级缓存是SqlSession级别的缓存. 查询缓存 mybatis提供查询缓存.用于减轻数据压力,提高数据库性能. mybaits提供一级缓存,和二级缓存. 一级缓存是SqlSession级别的缓存.在操作数据库时须要构造sqlSession对象,在对象中有一个数据结构(HashMa

MyBatis MapperScannerConfigurer配置――MyBatis学习笔记之八

MyBatis MapperScannerConfigurer配置——MyBatis学习笔记之八 2012-09-02 20:01:42 标签:Spring MyBatis MapperScannerConfigurer bean默认命名 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://legend2011.blog.51cto.com/3018495/980150 在上一篇博文的示例中,我们在beans.xml中配置了stu

MyBatis association的两种形式——MyBatis学习笔记之四

一.嵌套的resultMap 这 种方法本质上就是上篇博文介绍的方法,只是把教师实体映射从association元素中提取出来,用一个resultMap元素表示.然后 association元素再引用这个resultMap元素.修改上篇博文示例的StudentMapper.xml如下: <?xml version="1.0" encoding="utf8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org