4.MyBatis映射

news2025/1/10 23:48:37

需求分析

1.订单商品数据模型
(1).表
用户表user:记录了购买商品的用户信息
订单表orders:记录了用户所创建的订单信息
订单明细表orderdetail:记录了订单的详细信息
商品表item:记录了商品详细信息

(2).表与表之间的业务关系
在分析表与表之间的业务关系时,需要建立在某个具体业务的场景,先分析数据库级别之间有关系的表之间的业务关系。

  • user —> orders:一个用户可以创建多个订单,一对多
  • orders —> user:一个订单只由一个用户创建,一对一
  • orders —> orderdetail:一个订单可以包括多个订单明细,一对多,因为一个订单可以购买多个商品,每个商品的购买信息存在orderdetail
  • orderdetail —> orders:一个订单明细只能包括在一个订单中,一对一
  • orderdetail —> itesms:一个订单明细只对应一个商品信息,一对一
  • items –> orderdetail:一个商品可以包括在多个订单明细 ,一对多

2.数据准备
(1).订单表orders

CREATE TABLE `orders` (
	`order_id` int(11) NOT NULL,
	`user_id` int(11) NOT NULL,
	`order_no` varchar(100) NOT NULL,
	`note` varchar(100) NOT NULL,
	`create_time` datetime(6) NOT NULL,
  	PRIMARY KEY (`order_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into orders values(1,1,"20221207173000000001","Steven买了一台电脑和两部手机","2022-12-07 17:30:00");
insert into orders values(2,2,"20221207173500000002","Sherry买了一部手机和两台电脑","2022-12-07 17:35:00");

(2).订单详情表orderdetail

CREATE TABLE `orderdetail` (
	`order_detail_id` int(11) NOT NULL,
	`order_id` int(11) NOT NULL,
	`item_id` int(11) NOT NULL,
	`item_num` int(11) NOT NULL,
	`create_time` datetime(6) NOT NULL,
  	PRIMARY KEY (`order_detail_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into orderdetail values(1,1,1,1,"2022-12-07 17:30:00");
insert into orderdetail values(2,1,2,2,"2022-12-07 17:30:00");
insert into orderdetail values(3,2,1,2,"2022-12-07 17:35:00");
insert into orderdetail values(4,2,2,1,"2022-12-07 17:35:00");

(3).商品表item

CREATE TABLE `item` (
	`item_id` int(11) NOT NULL,
	`item_name` varchar(100) NOT NULL,
	`item_price` decimal(6,2) NOT NULL,
	`create_time` datetime(6) NOT NULL,
  	PRIMARY KEY (`item_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into item values(1,"电脑",9999.99,"2022-12-07 00:00:00");
insert into item values(2,"手机",6666.66,"2022-12-07 00:00:00");

关联查询

1.一对一(查询所有订单信息,关联查询下单用户信息)
(1).修改SQL映射文件
在mybatis.xml文件中,修改SQL映射文件,具体代码如下。

<!-- 2.在全局配置文件中加载SQL映射文件 -->
<mappers>
    <mapper resource="mapper/OrdersUserMapper.xml"/>
</mappers>

(2).编写po类
在po目录下新建Orders类,具体代码如下。

public class Orders {
    private Integer orderId;

    private Integer userId;

    private String orderNo;

    private String note;

    private Date createTime;

    //get和set方法......
}

在bo目录下新建OrdersUser类,具体代码如下。

public class OrdersUser extends Orders {
    private User user;

    //get和set方法......
}

(3).编写Mapper接口
并在mapper目录下新建OrdersUserMapper接口,具体代码如下。

public interface OrdersUserMapper {
    List<OrdersUser> findOrdersUser();
}

(4).编写SQL映射
在mapper目录下新建OrdersUserMapper.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.steven.mapper.OrdersUserMapper">
    <resultMap  id="ordersUserMap" type="com.steven.bo.OrdersUser">
        <id column="order_id" property="orderId"/>
        <result column="order_no" property="orderNo"/>
        <result column="note" property="note"/>
        <association javaType="com.steven.po.User" property="user">
            <id column="user_id" property="id"/>
            <result column="username" property="username"/>
            <result column="address" property="address" />
        </association>
    </resultMap>

    <select id="findOrdersUser" resultMap="ordersUserMap">
	    SELECT a.*,b.username,b.address
	    FROM orders as a join user as b
	    on a.user_id = b.id
	</select>
</mapper>

(5).编写测试类
Test类中调整获取Mapper和业务操作代码,具体代码如下。

public class Test {
    public static void main(String[] args) throws Exception {
        //1.获取MyBatis全局配置文件流
        String resource = "config/mybatis.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        //2.根据MyBatis配置信息创建会话工厂
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        //3.获取会话对象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //4.获取Mapper
        OrdersUserMapper ordersUserMapper = sqlSession.getMapper(OrdersUserMapper.class);
        //5.业务操作
        List<OrdersUser> ordersUserList = ordersUserMapper.findOrdersUser();
        Iterator<OrdersUser> iterator = ordersUserList.iterator();
        while (iterator.hasNext()) {
            OrdersUser ordersUser = iterator.next();
            System.out.println("orderNo:" + ordersUser.getOrderNo());
            System.out.println("note:" + ordersUser.getNote());
            System.out.println("username:" + ordersUser.getUser().getUsername());
            System.out.println("address:" + ordersUser.getUser().getAddress());
            System.out.println();
        }
        sqlSession.close();
    }
}
orderNo:20221207173000000001
note:Steven买了一台电脑和两部手机
username:steven
address:nanjing

orderNo:20221207173500000002
note:Sherry买了一部手机和两台电脑
username:sherry
address:taizhou

(6).工程目录
在这里插入图片描述

2.一对多(查询所有订单信息关联查询订单明细信息)
(1).修改SQL映射文件
在mybatis.xml文件中,修改SQL映射文件,具体代码如下。

<!-- 2.在全局配置文件中加载SQL映射文件 -->
<mappers>
    <mapper resource="mapper/OrdersOrderDetailMapper.xml"/>
</mappers>

(2).编写po类
在po目录下新建Orders类,具体代码如下。

public class OrderDetail {
    private Integer orderDetailId;

    private Integer orderId;

    private Integer itemId;

    private Integer itemNum;

    private Date createTime;

    //get和set方法......
}

在bo目录下新建OrdersOrderDetail类,具体代码如下。

public class OrdersUser extends Orders {
    List<OrderDetail> orderDetailList;

    //get和set方法......
}

(3).编写Mapper接口
并在mapper目录下新建OrdersOrderDetailMapper接口,具体代码如下。

public interface OrdersUserMapper {
    List<OrdersOrderDetail> getOrdersOrderDetail();
}

(4).编写SQL映射
在mapper目录下新建OrdersOrderDetailMapper.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.steven.mapper.OrdersOrderDetailMapper">
    <resultMap id="ordersUserOrderDetailMap" type="com.steven.bo.OrdersOrderDetail">
        <id column="order_id" property="orderId"/>
        <result column="order_no" property="orderNo"/>
        <result column="note" property="note"/>
        <collection ofType="com.steven.po.OrderDetail" property="orderDetailList">
            <id column="order_detail_id" property="orderDetailId"/>
            <result column="orderDetail_id" property="orderDetailId"/>
            <result column="order_id" property="orderId"/>
            <result column="item_id" property="itemId"/>
            <result column="item_num" property="itemNum"/>
        </collection>
    </resultMap>

    <select id="getOrdersOrderDetail" resultMap="ordersUserOrderDetailMap">
	    select a.*,b.username,b.address,c.item_id,c.item_num
	    from orders as a inner join user as b on a.user_id = b.id
	    inner join orderDetail as c on a.order_id = c.order_id
	</select>
</mapper>

(5).编写测试类
Test类中调整获取Mapper和业务操作代码,具体代码如下。

public class Test {
    public static void main(String[] args) throws Exception {
        //1.获取MyBatis全局配置文件流
        String resource = "config/mybatis.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        //2.根据MyBatis配置信息创建会话工厂
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        //3.获取会话对象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //4.获取Mapper
        OrdersOrderDetailMapper ordersOrderDetailMapper = sqlSession.getMapper(OrdersOrderDetailMapper.class);
        //5.业务操作
        List<OrdersOrderDetail> ordersOrderDetailList = ordersOrderDetailMapper.getOrdersOrderDetail();
        Iterator<OrdersOrderDetail> oodIterator = ordersOrderDetailList.iterator();
        while (oodIterator.hasNext()) {
            OrdersOrderDetail ordersOrderDetail = oodIterator.next();
            System.out.println("orderNo:" + ordersOrderDetail.getOrderNo());
            System.out.println("note:" + ordersOrderDetail.getNote());
            List<OrderDetail> orderDetailList = ordersOrderDetail.getOrderDetailList();
            System.out.println("orderDetailList:" + orderDetailList.size()+"条");
            Iterator<OrderDetail> odIterator = orderDetailList.iterator();
            while (odIterator.hasNext()) {
                OrderDetail orderDetail = odIterator.next();
                System.out.print("orderId:" + orderDetail.getOrderId());
                System.out.print(",itemId:" + orderDetail.getItemId());
                System.out.println(",itemNum:" + orderDetail.getItemNum());
            }
            System.out.println();
        }
        sqlSession.close();
    }
}
orderNo:20221207173000000001
note:Steven买了一台电脑和两部手机
orderDetailList:2条
orderId:1,itemId:1,itemNum:1
orderId:1,itemId:2,itemNum:2

orderNo:20221207173500000002
note:Sherry买了一部手机和两台电脑
orderDetailList:2条
orderId:2,itemId:1,itemNum:2
orderId:2,itemId:2,itemNum:1

(6).工程目录
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/73327.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Nginx的反向代理和负载均衡

Nginx&#xff1a; Nginx作为面试中的大…小头目&#xff0c;自然是不能忽视的&#xff0c;而以下两点就是它能成为面试中头目的招牌。 反向代理和负载均衡 在此之前&#xff0c;我们先对Nginx做一个简单的了解 Nginx概述&#xff1a; Nginx (engine x) 是一个高性能的HTTP…

Ansible——inventory 主机清单

Ansible——inventory 主机清单Ansible——inventory 主机清单inventory简介ansible配置文件的优先级ansible命令常用参数主机清单文件hosts&#xff08;/etc/ansible/hosts&#xff09;通过列表的方式标识主机范围指定主机端口使用主机名表示主机范围inventory 中的变量主机变…

JS 数组方法 every 和 some 的区别

1. 前言 2. every 和 some 相同点 3. every 和 some 的区别 4. every 和 some 总结 1. 前言 JS 数组方法 every 和 some 的区别 &#xff1f; 这是某位前端玩家遇到的面试题 特定场景合理的使用 JS 方法&#xff0c;不仅可以减少我们的代码量&#xff0c;还能更轻松的阅读…

宇航服,真正的“科技”与“狠活”!

千百年的探索仰望和摘星的遐想&#xff0c;已照进现实&#xff0c;浩瀚的天宫&#xff0c;我们亦可置身其中。 北京时间2022年12月4日20时09分&#xff0c;神舟十四号载人飞船返回舱在东风着陆场成功着陆&#xff0c;标志着太空出差183天的宇航员正式回家&#xff01;据悉&…

基于PCA 和迭代 Canny Edge皮肤病变分割算法研究附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;修心和技术同步精进&#xff0c;matlab项目合作可私信。 &#x1f34e;个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知。 更多Matlab仿真内容点击&#x1f447; 智能优化算法 …

NLP_learning 中文基本任务与处理(分词、停用词、词性标注、语句依存分析、关键词抽取、命名实体识别)介绍、jieba工具库

文章目录1、分词2、停用词和N-gram停用词N-gram3、 更多任务&#xff08;词性标注、依赖分析、NER、关键词抽取&#xff09;词性标注句法依存分析命名实体识别关键词抽取4、 jieba工具库使用&#xff08;1&#xff09;基本分词函数与用法&#xff08;2&#xff09;词性标注&…

【LeetCode】C++:数组类算法-双索引技巧-对撞指针

目录 167. 两数之和 II - 输入有序数组 125.验证回文串 345.反转字符串中的元音字母 11.盛最多水的容器 209.长度最小的数组 167. 两数之和 II - 输入有序数组 给你一个下标从1开始的整数数组 numbers &#xff0c;该数组已按非递减顺序排列 &#xff0c;请你从数组中找出…

视频剪辑软件哪个好用?快把这些软件收好

现如今自媒体行业正在如火如荼的发展&#xff0c;越来越多的人加入进视频剪辑的队伍中。小伙伴们也有萌生想要剪辑视频的念头吗&#xff1f;大家是否苦于不知道该如何视频剪辑呢&#xff1f;为了帮助大家解决这个问题&#xff0c;今天我就来为大家教几种不错的剪辑方法&#xf…

YOLOv5图像分割中的NMS处理

在上一篇文章YOLOv5图像分割--SegmentationModel类代码详解有讲到图像经过YOLOv5网络后得到的输出形式&#xff0c;主要是调用了BaseModel类下的forward得到的输出&#xff0c;输出的shape为【batch,25200,117】&#xff0c;这里的25200相当于总的anchors数量【以640*640的输入…

vuex原理和下载

vuex&#xff1a;状态管理模式 vue全家桶&#xff1a;vue-cli&#xff08;脚手架&#xff09;、vue-router&#xff08;路由管理器&#xff09;、vuex&#xff08;状态管理模式&#xff09; 原理图示&#xff1a; 原理描述&#xff1a; vuex在vue组件外面进行组件状态的管理…

引用的小细节内联函数

1.引用的细节 引用&#xff0c;简单来说就是“取别名”。既然是别名&#xff0c;那么引用就一定具有以下的特点 引用在定义时必须初始化。 就好比起别名起码得告诉别人是给谁起的别名吧 一个变量可以有多个引用 就好比一个人可以有多个别名。比如张某某&#xff0c;有两个外号…

智慧农业创造新兴业态,推动农业产业现代化步伐

农业是国民经济的基础&#xff0c;在国家经济发展中起着不可替代的作用&#xff0c;随着物联网、人工智能、信息技术的快速发展&#xff0c;农业逐渐走向智能化、现代化和自动化&#xff0c;智慧农业已经深入到农业生产的各个环节&#xff0c;成为了现代农业发展新的方向。 所谓…

JAVA12_08学习总结(CSS)

今日内容 1. frameset 框架集标签frameset框架集标签不能放在body中rows--划分页面为上下部分cols--划分页面为左右部分框架标签frame框架的名称name属性<frame src"#" name"#" />src后代表这个框架中打开的页面链接name后代表这个被打开页面的nam…

JavaScript -- 11. BOM及常用对象介绍

文章目录BOM对象1 BOM2 navigator3 location3.1 常用方法3.2 url各部分名称4 historyBOM对象 1 BOM 浏览器对象模型 BOM为我们提供了一组对象&#xff0c;通过这组对象可以完成对浏览器的各种操作 BOM对象&#xff1a; Window —— 代表浏览器窗口&#xff08;全局对象&…

哥斯拉连webshell需要配置(哥斯拉连接Webshell实践)

1. 哥斯拉连webshell需要配置环境 kali linux   docker+vulhub   nginx(1.19.6)+php(7.4.15) 2. 哥斯拉连webshell需要配置过程 2.1 vulhub镜像拉取 vulhub安装的话去官网上有安装教程   Vulhub - Docker-Compose file for vulnerability environment   安装好之后…

VUE基本认知

1&#xff1a;vue介绍 渐进式 JavaScript 框架&#xff08;有2个库&#xff0c;核心库和插件库&#xff0c;如果能用核心库解决的就是用核心库&#xff0c;核心库解决不了的&#xff0c;就使用插件库&#xff09; 渐&#xff1a;逐渐&#xff0c; 进&#xff1a;添加 作者: 尤…

原生数据湖体系

背景&#xff1a; 随着数据量的爆发式增长&#xff0c;数字化转型称为了整个IT行业的热点&#xff0c;数据也开始需要更深度的价值挖掘&#xff0c;因此需要确保数据中保留的原始信息不丢失&#xff0c;从而应对未来不断变化的需求。当前以oracle为代表的数据库中间件已经逐渐…

nginx详细配置负载均衡全过程以及宕机情况处理

一、准备 1.下载安装nginx服务器&#xff08;win10/Linux同样适用&#xff09; 2.两个以上服务的服务地址 二、详细步骤以及宕机情况处理 &#xff08;1&#xff09;编辑 nginx.conf 配置文件&#xff0c;该文件在conf文件夹下面。 轮询&#xff1a; upstream my_server …

【物理应用】超声场可视化仿真模拟【含GUI Matlab源码 1494期】

⛄一、简介&#xff08;附论文&#xff09; 通过对超声场理论的数学物理方法计算&#xff0c;分别对圆型和矩型换能器的声轴线上声压分布、轴方向横截面的声压的分布及声场的指向性的表达式作出推导和演算&#xff0c;并得出结论&#xff1b;以及研究脉冲波声场分布特性&#…

计算机组成大题分析(五)

常见x86汇编指令解释 例题&#xff1a;已知 f(n)n! nX(n-1)XX2X1&#xff0c;计算 f(n)的 C 语言函数 f(n) 的源程序&#xff08;圈住的地方&#xff09;及其在 32 位计算机 M 上的部分机器级代码如下: 其中&#xff0c;机器级代码行包括行号、虚拟地址、机器指令和汇编指令&am…