一对多关系更加常见,比如用户和订单,一个用户可以有多个订单

DROP TABLE IF EXISTS customer;
/*用户表*/
CREATE TABLE customer(
`pk` INT PRIMARY KEY AUTO_INCREMENT,
`name` VARCHAR(16),
`email` VARCHAR(16),
`password` VARCHAR(16)
);
/*插入三条测试数据*/
INSERT INTO customer(`name`,`email`,`password`) VALUES('张三','2A@b.com','123456');
INSERT INTO customer(`name`,`email`,`password`) VALUES('李六','MNO@b.com','qazwer');
INSERT INTO customer(`name`,`email`,`password`) VALUES('王五','XYZ@b.com','edcrfv'); DROP TABLE IF EXISTS `order`;
/*订单表*/
CREATE TABLE `order`(
`pk` INT PRIMARY KEY AUTO_INCREMENT,
`customer_pk` INT,
`order_id` int,
`order_total` float,
FOREIGN KEY (customer_pk) REFERENCES customer(pk)
);
/*插入8条测试数据*/
INSERT INTO `order`(`customer_pk`,`order_id`,`order_total`) VALUES('1','1','462.9');
INSERT INTO `order`(`customer_pk`,`order_id`,`order_total`) VALUES('3','2','32.5');
INSERT INTO `order`(`customer_pk`,`order_id`,`order_total`) VALUES('2','3','216.93');
INSERT INTO `order`(`customer_pk`,`order_id`,`order_total`) VALUES('1','4','5323.32');
INSERT INTO `order`(`customer_pk`,`order_id`,`order_total`) VALUES('3','5','533.1');
INSERT INTO `order`(`customer_pk`,`order_id`,`order_total`) VALUES('2','6','924.5');
INSERT INTO `order`(`customer_pk`,`order_id`,`order_total`) VALUES('1','7','121.3');
INSERT INTO `order`(`customer_pk`,`order_id`,`order_total`) VALUES('2','8','65.34');

实体类:Customer和Order

package net.sonng.onetomany;

import java.util.List;
//用户实体类
public class Customer {
private int pk;
private String name;
private String email;
private String password;
private List<Order> orders;//一个用户可拥有多个订单 //省略getter、setter、toString
}
package net.sonng.onetomany;
//订单实体类
public class Order {
private int pk;
private int customer_pk;
private int order_id;
private Float order_total;
private Customer customer; //一条订单只属于一个用户
//省略getter、setter、toString
}

假如要根据用户的主键,查询用户的信息,然后再查询其所有的订单信息,sqlMapper配置如下

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//ibatis.apache.org//DTDMapper 3.0//EN" "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">
<mapper namespace="net.sonng.onetomany.CustomerDao">
<!-- 根据用户主键查询用户信息,按『costomerMap』封装 -->
<select id="selectCustomerByPk" parameterType="int" resultMap="customerMap" >
SELECT * FROM customer WHERE pk=#{pk}
</select> <resultMap id="customerMap" type="net.sonng.onetomany.Customer">
<id property="pk" column="pk" />
<result property="name" column="name" />
<result property="email" column="email" />
<result property="password" column="password" />
<!-- 根据查到的customer表的主键pk,再用另一个sql查询所有的订单,封装成ArrayList<Order>,再映射到orders属性 -->
<!-- collection解决了一对多关联,该元素下还有个属性fetchType="lazy/eager",用于定义是否立即进行进一步查询 -->
<!-- Customer类的属性 查询结果列 封装类型 封装元素类型 -->
<collection property="orders" column="pk" javaType="ArrayList" ofType="net.sonng.onetomany.Order"
select="net.sonng.onetomany.OrderDao.selectOrderByCustomerPk" >
<id property="pk" column="pk" />
<result property="order_id" column="order_id" />
<result property="order_total" column="order_total" />
</collection>
</resultMap>
</mapper>

根据订单主键查询订单信息,同时查询到其所属的用户信息

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//ibatis.apache.org//DTDMapper 3.0//EN" "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">
<mapper namespace="net.sonng.onetomany.OrderDao"> <!-- 根据订单的主键,查询订单的信息,因为一条订单只属于一个用户,数据量不大,因而用联合查询一次查出来 -->
<select id="selectOrderByPk" parameterType="int" resultMap="orderMap">
SELECT * FROM customer,`order` WHERE customer.pk=order.customer_pk AND order.pk=#{pk}
</select>
<!-- 下面这条select就是上面的resultMap要引用的,可以用resultMap或者resultType封装,resultMap看似形成了循环嵌套 -->
<select id="selectOrderByCustomerPk" parameterType="int" resultMap="orderMap" >
SELECT * FROM `order` WHERE customer_pk=#{pk}
</select> <resultMap type="net.sonng.onetomany.Order" id="orderMap">
<id property="pk" column="pk" />
<result property="costomer_id" column="costomer_id" />
<result property="order_id" column="order_id" />
<result property="order_total" column="order_total" />
<!--这是多对一关联,多个订单都属于一个用户,跟一对一一样还是用association元素-->
<association property="customer" javaType="net.sonng.onetomany.Customer">
<id property="pk" column="pk" />
<result property="name" column="name" />
<result property="email" column="email" />
<result property="password" column="password" />
</association>
</resultMap> </mapper>

测试类:

package net.sonng.test;

import java.util.List;

import net.sonng.onetomany.Customer;
import net.sonng.onetomany.CustomerDao;
import net.sonng.onetomany.Order;
import net.sonng.onetomany.OrderDao; import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class Test {
public static void main(String[] args){
ApplicationContext ac=new ClassPathXmlApplicationContext("ac.xml");
CustomerDao customerDao=ac.getBean("customerDao",CustomerDao.class);
OrderDao orderDao=ac.getBean("orderDao",OrderDao.class); Customer ct=customerDao.selectCustomerByPk(2);//这个查询会将用户信息连带其所有订单信息一起查询出来
System.out.println(ct);
List<Order> orders=ct.getOrders(); //如果加了fetch=lazy,那么要到访问订单信息的时候,才去查询
for (Order order:orders) {
System.out.println(order);
} Order order=orderDao.selectOrderByPk(1);
System.out.println(order);
System.out.println(order.getCustomer());
}
}

输出:

Customer [pk=2, name=李六, email=MNO@b.com, password=qazwer //根据用户主键查询到用户信息

Order [pk=3, customer_pk=2, order_id=3, order_total=216.93 //这三条order都是查询到用户信息后,进一步查询到的所有订单信息

Order [pk=6, customer_pk=2, order_id=6, order_total=924.5

Order [pk=8, customer_pk=2, order_id=8, order_total=65.34

Order [pk=1, customer_pk=0, order_id=1, order_total=462.9 //根据订单的主键查询到的订单信息

Customer [pk=1, name=张三, email=2A@b.com, password=123456//查询到订单信息后,进一步查到其所属的用户信息

0050 MyBatis关联映射--一对多关系的更多相关文章

  1. mybatis关联映射一对多

    实际项目中也存在很多的一对多的情况,下面看看这个简单的例子 table.sql CREATE TABLE tb_clazz( id INT PRIMARY KEY AUTO_INCREMENT, CO ...

  2. 0051 MyBatis关联映射--多对多关系

    用户与订单时一对多关系,再加上商品信息的话,订单与商品之间就是多对多关系了 DROP DATABASE IF EXISTS testdb; USE testdb; /*用户表,记录用户信息:用户与订单 ...

  3. Hibernate 多表关联映射- 一对多关系映射(one-to-many)

    Hibernage.cfg.xml: <hibernate-configuration> <session-factory name="sessionFactory&quo ...

  4. (转)Hibernate关联映射——一对多(多对一)

    http://blog.csdn.net/yerenyuan_pku/article/details/70152173 Hibernate关联映射——一对多(多对一) 我们以客户(Customer)与 ...

  5. 0049 MyBatis关联映射--一对一关系

    世上的事务总不是孤立存在的,表现在Java类里面,则是类与类之间的关系,比如继承is-a.依赖use-a.关联has-a,反映在数据库中,则是表与表之间的关系,比如外键 关联关系存在着以下几种类型:一 ...

  6. MyBatis学习(六)MyBatis关联映射之一对多映射

    数据库中一对多通常使用主外键关联,外键应该在多方,即多方维护关系. 下面举一个简单实例来看看MyBatis怎么处理一对多的关系. 1.创建一个项目,导入所需jar包,导入db.properties配置 ...

  7. MyBatis(五):mybatis关联映射

    Mybatis中表与表之间的关系分为一下4类: 1)一对一 2)一对多 3)多对一 4)多对多 创建数据Demo表 数据库表: 用户表user:记录了购买商品的用户信息. 订单表orders:记录了用 ...

  8. mybatis关联映射多对多

    项目开发中,多对多关系也是非常常见的关系 在数据库中创建表的脚本 table.sql CREATE TABLE tb_user( id INT PRIMARY KEY AUTO_INCREMENT, ...

  9. Hibernate之关联映射(一对多和多对一映射,多对多映射)

    ~~~接着之前的Hibernate框架接着学习(上篇面试过后发现真的需要学习以下框架了,不然又被忽悠让去培训.)~~~ 1:Hibernate的关联映射,存在一对多和多对一映射,多对多映射: 1.1: ...

随机推荐

  1. 在Spring3中使用注解(@Scheduled)创建计划任务

    Spring3中加强了注解的使用,其中计划任务也得到了增强,现在创建一个计划任务只需要两步就完成了: 创建一个Java类,添加一个无参无返回值的方法,在方法上用@Scheduled注解修饰一下: 在S ...

  2. 【Javascript】js图形编辑器库介绍

    10个JavaScript库绘制自己的图表 jopen 2015-04-06 18:18:38 • 发布 摘要:10个JavaScript库绘制自己的图表 JointJS JointJS is a J ...

  3. Struts2的动态Action实现

    源自:Struts2的动态Action实现 在Struts2中动态方法调用有三种方式. 一.指定method属性在struts.xml中指定action的method属性. <package n ...

  4. 如何使用 awk 按模式筛选文本或字符串

    在筛选文本时,有时你可能想根据某个给定的条件或使用一个可被匹配的特定模式,去标记某个文件或数行字符串中的某几行.使用 awk 来完成这个任务是非常容易的,这也正是 awk 中可能对你有所帮助的几个功能 ...

  5. 如何使用 awk 输出文本中的字段和列

    首先我们要知道,awk 能够自动将输入的行,分隔为若干字段.每一个字段就是一组字符,它们和其他的字段由一个内部字段分隔符分隔开来. 如果你熟悉 Unix/Linux 或者懂得 bash shell 编 ...

  6. 超酷的实时颜色数据跟踪javascript类库 - Tracking.js

    来源:GBin1.com 今天介绍这款超棒的Javascript类库是 - Tracking.js,它能够独立不依赖第三方类库帮助开发人员动态跟踪摄像头输出相关数据. 这些数据包括了颜色或者是人, 这 ...

  7. Linux命令之编辑

    vi是终端命令行里功能最强的文本编辑器了,但眼下须要用到的仅仅是文本编辑功能.与GCC.make等工具的整合应用如今还不须要,所以操作难度不大,习惯就好. Linux发行版所带的一般不是vi,而是vi ...

  8. python gevent使用例子

    python gevent使用例子 from gevent.pool import Pool POOL_SIZE = 100 def process(func, param1_list, param2 ...

  9. Tmux 的常用命令详解

    Tmux 的常用命令详解  常用命令: tmux #开启tmux tmux ls #显示已有tmux列表(C-b s) tmux attach-session -t 数字 #选择tmux C-b c ...

  10. js实现页面跳转的两种方式

      CreateTime--2017年8月24日08:13:52Author:Marydon js实现页面跳转的两种方式 方式一: window.location.href = url 说明:我们常用 ...