mybatis 一对多和多对一
一、表
二、实体
1.person
- package com.kerwin.mybatis.pojo;
- import java.util.List;
- public class Person {
- private int id;
- private String name;
- private List<Orders> orderList;
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public List<Orders> getOrderList() {
- return orderList;
- }
- public void setOrderList(List<Orders> orderList) {
- this.orderList = orderList;
- }
- @Override
- public String toString() {
- return "Person [id=" + id + ", name=" + name + "]";
- }
- public Person() {
- super();
- // TODO Auto-generated constructor stub
- }
- public Person(int id, String name, List<Orders> orderList) {
- super();
- this.id = id;
- this.name = name;
- this.orderList = orderList;
- }
- }
2.order
- package com.kerwin.mybatis.pojo;
- public class Orders {
- private int id;
- private double price;
- private Person person;
- public Person getPerson() {
- return person;
- }
- public void setPerson(Person person) {
- this.person = person;
- }
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public double getPrice() {
- return price;
- }
- public void setPrice(double price) {
- this.price = price;
- }
- @Override
- public String toString() {
- return "Orders [id=" + id + ", price=" + price + "]";
- }
- public Orders() {
- super();
- // TODO Auto-generated constructor stub
- }
- }
三、映射mapper文件
1. PersonMapper.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE mapper
- PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
- <mapper namespace="com.kerwin.mybatis.pojo.Person">
- <resultMap type="com.kerwin.mybatis.pojo.Person" id="personreSultMap">
- <id column="p_id" property="id"/>
- <result column="name" property="name"/>
- <collection property="orderList" ofType="com.kerwin.mybatis.pojo.Orders" column="pid">
- <id column="o_id" property="id"/>
- <result column="price" property="price"/>
- </collection>
- </resultMap>
- <select id="selectPersonFetchOrder" parameterType="int" resultMap="personreSultMap" >
- select p.*,o.* from person p,orders o where o.pid=p.p_id and p.p_id=#{id}
- </select>
- </mapper>
2. OrdersMapper.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE mapper
- PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
- <mapper namespace="com.kerwin.mybatis.pojo.Orders">
- <resultMap type="com.kerwin.mybatis.pojo.Orders" id="OrdersResultMap">
- <id column="o_id" property="id"/>
- <result column="price" property="price"/>
- <association property="person" javaType="com.kerwin.mybatis.pojo.Person">
- <id column="p_id" property="id"/>
- <result column="name" property="name"/>
- </association>
- </resultMap>
- <select id="selectOrdersFetchPerson" resultMap="OrdersResultMap">
- select p.*,o.* from person p,orders o where o.pid=p.p_id and o.o_id=#{id}
- </select>
- </mapper>
3.sqlMapConfig.xml
- <?xml version="1.0" encoding="UTF-8" ?>
- <!DOCTYPE configuration
- PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-config.dtd">
- <configuration>
- <typeAliases>
- <typeAlias type="com.kerwin.mybatis.pojo.Author" alias="Author"/>
- </typeAliases>
- <environments default="development">
- <environment id="development">
- <transactionManager type="JDBC"/>
- <dataSource type="POOLED">
- <property name="driver" value="com.mysql.jdbc.Driver"/>
- <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/>
- <property name="username" value="root"/>
- <property name="password" value="root"/>
- </dataSource>
- </environment>
- </environments>
- <mappers>
- <mapper resource="com/kerwin/mybatis/pojo/AuthorMapper.xml"/>
- <mapper resource="com/kerwin/mybatis/pojo/PostMapper.xml"/>
- <mapper resource="com/kerwin/mybatis/pojo/PersonMapper.xml"/>
- <mapper resource="com/kerwin/mybatis/pojo/OrdersMapper.xml"/>
- </mappers>
- </configuration>
四。测试类
- /**
- *
- */
- package com.kerwin.mybatis.test;
- import java.io.InputStream;
- import org.apache.ibatis.io.Resources;
- import org.apache.ibatis.session.SqlSession;
- import org.apache.ibatis.session.SqlSessionFactory;
- import org.apache.ibatis.session.SqlSessionFactoryBuilder;
- import org.junit.BeforeClass;
- import org.junit.Test;
- import com.kerwin.mybatis.pojo.Orders;
- import com.kerwin.mybatis.pojo.Person;
- /**
- * @author Administrator
- *
- */
- public class PersonAndOrderTest {
- private static SqlSessionFactory sessionFactory;
- /**
- * @throws java.lang.Exception
- */
- @BeforeClass
- public static void setUpBeforeClass() throws Exception {
- SqlSessionFactoryBuilder factoryBuilder = new SqlSessionFactoryBuilder();
- InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
- sessionFactory = factoryBuilder.build(inputStream);
- }
- //一对多,查询person(一)级联查询订单order(多)
- @Test
- public void testSelectPersonFetchOrder() throws Exception {
- SqlSession session = sessionFactory.openSession();
- Person person = session.selectOne("com.kerwin.mybatis.pojo.Person.selectPersonFetchOrder", 1);
- System.out.println(person);
- System.out.println(person.getOrderList().size());
- for(Orders orders : person.getOrderList()){
- System.out.println(orders);
- }
- session.close();
- }
- //多对一,查询订单order(多)级联查询person(一)
- @Test
- public void testSelectOrdersFetchPerson() throws Exception{
- SqlSession session = sessionFactory.openSession();
- Orders orders = session.selectOne("com.kerwin.mybatis.pojo.Orders.selectOrdersFetchPerson", 1);
- System.out.println(orders);
- System.out.println(orders.getPerson());
- session.close();
- }
- }
五、测试结果
1.一对多,查询person(一)级联查询订单order(多)
2.多对一,查询订单order(多)级联查询person(一)
注意:两张表中的主键id字段名要唯一,例如不能都写id,不然的话,在一对多查询的时候就会出现:级联出来的订单项只有一条记录。我之前就是将两张表的主键id字段名都写为id,导致测试结果级联出来的多一直只有一条数据,具体如下:
mybatis 一对多和多对一的更多相关文章
- Java基础-SSM之mybatis一对多和多对一关系映射
Java基础-SSM之mybatis一对多和多对一关系映射 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.准备测试环境(创建数据库表) 1>.创建customers表: ...
- MyBatis一对多和多对多xml配置
MyBatis一对多和多对多xml配置 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE ma ...
- mybatis 一对多,多对一配置
一. 简介: 本实例使用顾客和订单的例子做说明: 一个顾客可以有多个订单, 一个订单只对应一个顾客 二. 例子: 1. 代码结构图: 2. 建表语句: CREATE DATABASE test; US ...
- mybatis 一对多和多对一 简单案例笔记
以案例说明(以下案例代码都敲过验证过) 多对一(多个学生对一个老师 即学生集合中都存一个老师对象) Mybatis多对一实现方式1: //定义Student 和 Teacher 实体 @Data p ...
- mybatis 一对多和多对一关联查询
首先 数据库量表之间字段关系(没有主外键) studentmajor表的id字段对应student表里major字段 两个实体类 package com.model; import java.uti ...
- mybatis一对多,多对一
假设两张表 person对order为一对多 实体类 person package com.kerwin.mybatis.pojo; import java.util.List; public cla ...
- Mybatis之关联关系(一对多、多对多)
目的: Mybatis关系映射之一对多 Mybatis关系映射之多对多 Mybatis关系映射之一对多 一对多 (订单对应多个订单项) 多对一 (订单项对应一个订单) 其是映射关系的基层思维是一样的 ...
- 六 mybatis高级映射(一对一,一对多,多对多)
1 订单商品数据模型 以订单商品数据为模型,来对mybaits高级关系映射进行学习.
- Mybatis(四) 高级映射,一对一,一对多,多对多映射
天气甚好,怎能不学习? 一.单向和双向 包括一对一,一对多,多对多这三种情况,但是每一种又分为单向和双向,在hibernate中我们就详细解析过这单向和双向是啥意思,在这里,在重复一遍,就拿一对多这种 ...
随机推荐
- c++ 模板仿函数初探
一直以来对于C++的使用基本上都是C with class,对于各种尖括号的模板都是敬而远之,最近忽然觉得该好好看看模板了.于是就有了这篇blog. 本文以一个查找问题为例来说明模板仿函数. 在C中, ...
- MySQL的下载及安装
前言:不仅要知其然,还要知所以然 MySQL数据库作为关系型数据库中的佼佼者,因其体积小,速度快,成本低,不仅受到了市场的极大追捧,也受到了广大程序员的青睐.接下来,就给大家说一下,MySQL的下载和 ...
- wifidog 认证
首先简介一下什么是Portal认证.Portal认证.通常也会叫Web认证.未认证用户上网时,设备强制用户登录到特定站点,用户能够免费訪问当中的服务.当用户须要使用互联网中的其他信息时,必须在门户站点 ...
- iphone开发常用代码笔记
1.显示图像: 1 2 3 4 5 6 CGRect myImageRect = CGRectMake(0.0f, 0.0f, 320.0f, 109.0f); UIImageView *myImag ...
- python学习【第六篇】python迭代器与生成器
一.什么是迭代器 迭代器协议:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代(只能往后走不能往前退) 可迭代对象:实现了迭代器 ...
- splay tree旋转操作 hdu 1890
很神奇的旋转操作. 目前没看到其他数据结构能实现这个功能.平衡树不好处理区间操作,线段树很难旋转.splay tree搞这个就很简单了. 下面用的这个模板跑了700ms,好慢,估计是删除操作太费时了, ...
- 【BZOJ2298】[HAOI2011]problem a DP
[BZOJ2298][HAOI2011]problem a Description 一次考试共有n个人参加,第i个人说:“有ai个人分数比我高,bi个人分数比我低.”问最少有几个人没有说真话(可能有相 ...
- easy 正则表达式验证 封装
基于EasyUI ValidateBox 的表单验证,可以直接写正则表达式. 在页面加载时执行下面代码 if ($.fn.form) { $.extend($.fn.validatebox.defau ...
- MySQL权限系统(一).The MySQL Access Privilege System 概述
纯属个人阅读,如有翻译错误,请指出 The primary function of the MySQL privilege system is to authenticate a user who c ...
- HTTP 状态码简介(对照)
HTTP状态码 当浏览者访问一个网页时,浏览者的浏览器会向网页所在服务器发出请求.当浏览器接收并显示网页前,此网页所在的服务器会返回一个包含HTTP状态码的信息头(server header)用以响应 ...