实习知识整理11:确认订单并将订单的相关信息插入用户订单表和订单详情表

news2025/1/24 22:51:12

用户订单表:

 

订单详情表:

 

思路分析:首先我们需要知道当点击了确认订单按钮后,需要向后端传递哪些数据,先看用户订单表:ORDER_ID是不需要传的,这个可以在后台生成就行了;USER_ID是需要传的;ADDRESS_ID也是需要传的;ORDER_TIME可以在后台获得系统的时间,也是不需要传的;GET_TIME不需要;TOTAL总价是需要传的;NOTE备注也是需要传的。

再看订单详情表:ORDER_DETAIL_ID是自增的,不需要;ORDER_ID也是不需要的;ITEM_ID是需要的;BUY_COUNT也是需要的 

 

1. 提交表单需要传递的数据

补充:再上一篇博客中讲述了如何选择其他地址并渲染到页面上,此时我们在这边的,需要传递ADDRESS_ID, 所以当我们选择其他地址时,同时也是需要将ADDRESS_ID也跟着改变成相应的,不然提交表单时,会传错误的ADDRESS_ID

<input id="formAddressId" name="addressId" type="hidden" th:value="${defaultAddress.addressId}"/>

将需要传递的数据都放入表单中,如果不需要展示,直接设为隐藏就行了

 

 

 

 2. 后端接收数据并执行插入操作

我们需要向两个表中插入数据,所以要写两个mapper

UserOrderMapper.java 

public interface UserOrderMapper {

    // 新增订单信息
    int insertUserOrder(UserOrder userOrder);
}

UserOrderMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.shopping.mapper.UserOrderMapper">

    <resultMap id="userOrderBaseResultMap" type="UserOrder">
        <id column="ORDER_ID" property="orderId"/>
        <result column="USER_ID" property="userId"/>
        <result column="ADDRESS_ID" property="addressId"/>
        <result column="ORDER_TIME" property="orderTime"/>
        <result column="GET_TIME" property="getTime"/>
        <result column="TOTAL" property="total"/>
        <result column="NOTE" property="note"/>
    </resultMap>

    <!--insertUserOrder(UserOrder userOrder);-->
    <insert id="insertUserOrder" parameterType="UserOrder">
        INSERT INTO userorder (ORDER_ID,USER_ID,ADDRESS_ID,ORDER_TIME,GET_TIME,TOTAL,NOTE)
        VALUES (#{orderId},#{userId},#{addressId},#{orderTime},#{getTime},#{total},#{note})
    </insert>

</mapper>

 OrderDetailMapper.java

public interface OrderDetailMapper {
    //插入订单详情
    int insertOrderDetail(OrderDetail orderDetail);
}

OrderDetailMapper.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.example.shopping.mapper.OrderDetailMapper">

    <resultMap id="baseOrderDetailResultMap" type="Address">
        <id column="ORDER_DETAIL_ID" property="orderDetailId"/>
        <result column="ORDER_ID" property="orderId"/>
        <result column="ITEM_ID" property="itemId"/>
        <result column="BUY_COUNT" property="buyCount"/>
    </resultMap>

    <!--insertOrderDetail(OrderDetail orderDetail);-->
    <insert id="insertOrderDetail" parameterType="OrderDetail">
        INSERT INTO orderdetail (ORDER_ID,ITEM_ID,BUY_COUNT) VALUES (#{orderId},#{itemId},#{buyCount})
    </insert>
</mapper>

 

UserOrderService.java 接口

 使其的返回类型时ResultDTO

public interface UserOrderService {
    // 直接购买确认订单功能
    ResultDTO<UserOrder> confirmOrder(UserOrder userOrder, OrderDetail orderDetail);
}

 

 UserOrderServiceImpl.java 实现类

public class UserOrderServiceImpl implements UserOrderService {
    @Resource
    UserOrderMapper userOrderMapper;
    @Resource
    OrderDetailMapper orderDetailMapper;

    @Override
    public ResultDTO<UserOrder> confirmOrder(UserOrder userOrder, OrderDetail orderDetail) {
        ResultDTO<UserOrder> userOrderResultDTO = new ResultDTO<>();
        // 判断用户是否登录
        if (0!= userOrder.getUserId()) {
            int orderId = (int)(Math.random() * 1234567890);  // 生成随机的订单编号
            userOrder.setOrderId(orderId);
            userOrder.setOrderTime(new Timestamp(System.currentTimeMillis()));  // 将当前系统的时间直接填入
            
            
            int orderSubmit = userOrderMapper.insertUserOrder(userOrder);
            if (orderSubmit > 0) {
                // 订单插入成功,才能进行订单详情插入
                orderDetail.setOrderId(orderId);
                int orderDetailSubmit = orderDetailMapper.insertOrderDetail(orderDetail);
                if (orderDetailSubmit > 0) {
                    userOrderResultDTO.setCode(200);
                    userOrderResultDTO.setMsg("下单成功!");
                    userOrderResultDTO.setData(userOrder);
                } else {
                    userOrderResultDTO.setCode(500);
                    userOrderResultDTO.setMsg("下单失败!");
                    userOrderResultDTO.setData(null);
                }
            }
        } else {
            userOrderResultDTO.setCode(500);
            userOrderResultDTO.setMsg("下单失败!");
            userOrderResultDTO.setData(null);
        }
        return userOrderResultDTO;
    }
}

UserOrderController.java

    @RequestMapping("/confirmOrder")
    @ResponseBody
    // http://localhost:8082/project/order/confirmOrder
    public ResultDTO confirmOrder(UserOrder userOrder, OrderDetail orderDetail) throws Exception {
        // System.out.println("userOrder:" + userOrder);
        // System.out.println("orderDetail:" + orderDetail);
        ResultDTO<UserOrder> confirmOrderResult =  userOrderService.confirmOrder(userOrder, orderDetail);

        return  confirmOrderResult;
    }

这边是直接以ResultDTO的形式返回的,也可以使用ModelAndView进行数据的返回

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

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

相关文章

【赠书第13期】边缘计算系统设计与实践

文章目录 前言 1 硬件架构设计 2 软件框架设计 3 网络结构设计 4 安全性、可扩展性和性能优化 5 推荐图书 6 粉丝福利 前言 边缘计算是一种新兴的计算模式&#xff0c;它将计算资源推向网络边缘&#xff0c;以更好地满足实时性、低延迟和大规模设备连接的需求。边缘计算…

腾讯开源AppAgent,手机的大模型智能代理

腾讯研究团队开源了一款基于大语言模型的&#xff0c;用于手机端执行复杂任务的多模态智能代理框架——AppAgent。 据悉&#xff0c;AppAgent的功能与AutoGPT等智能代理类似&#xff0c;不依赖于操作系统的后台访问,而是通过UI界面进行点击、滑动等拟人化操作&#xff0c;与Ap…

继电保护测试仪的这4点用途和6点功能你知道几个?

众所周知&#xff0c;继电保护系统是电力系统中至关重要的组成部分。当电路出现故障时&#xff0c;它可以快速准确地切除故障部分&#xff0c;以确保电力系统的安全稳定运行。然后&#xff0c;为了提前发现和保证继电保护系统的故障和问题&#xff0c;通常需要使用继电保护测试…

嵌入式面试准备

题目都摘于网上 嵌入式系统中经常要用到无限循环&#xff0c;如何用C编写死循环 while(1){}或者for(;&#x1f609; 内存分区 代码区&#xff0c;全局区&#xff08;全局变量&#xff0c;静态变量&#xff0c;以及常量&#xff09;&#xff0c;栈区&#xff0c;堆区 const关键…

企业知识库:成为优秀企业的必备系统

导语&#xff1a; 在当今竞争激烈的商业环境中&#xff0c;企业需要不断创新和提高团队的协作效率&#xff0c;以保持竞争优势。而构建一个优秀的企业知识库系统已经成为众多企业必备的系统之一。本文将介绍企业知识库的定义、作用以及如何搭建一个完整有效的企业知识库。 什么…

基于MATLAB的正态分布与卡方分布(附完整代码与例题)

目录 一. 理论部分 二. MATLAB所使用的函数介绍 2.1 概率密度函数 2.2 概率分布函数 2.3 逆概率分布函数 三. 例题与代码 例题1 例题2 例题3 例题4 一. 理论部分 将连续随机变量的概率密度函数记为&#xff0c;既然跟概率相关&#xff0c;那必然满足两个重要的性质&a…

智能酒精壁炉历史轨迹:文化传统与现代融合的取暖方式

智能酒精壁炉作为一种取暖装置&#xff0c;承载着丰富的历史和文化传统。深入了解其在不同文化中的演变过程&#xff0c;以及如何成为现代家庭的取暖方式&#xff0c;可以了解智能酒精壁炉在历史中的发展轨迹。 古希腊和古罗马时期&#xff0c;人们使用酒精和其他可燃性液体作…

猫冻干什么牌子口碑好?专业人士分享口碑好的五款冻干猫粮牌子

近几年&#xff0c;冻干猫粮在宠物圈内非常流行&#xff0c;许多品牌都推出了冻干猫粮。在所有的猫食品中&#xff0c;冻干无疑是最具营养、动物蛋白含量最高的食品之一。冻干作为现在宠物圈最火的猫食品&#xff0c;受到了众多猫友们的喜爱和追捧。但有些铲屎官在选择冻干猫粮…

手动创建idea SpringBoot 项目

步骤一&#xff1a; 步骤二&#xff1a; 选择Spring initializer -> Project SDK 选择自己的JDK版本 ->Next 步骤三&#xff1a; Maven POM ->Next 步骤四&#xff1a; 根据JDK版本选择Spring Boot版本 11版本及以上JDK建议选用3.2版本&#xff0c;JDK为11版本…

rosdep init/update失败(转载)

sudo rosdep init rosdep update 如果你直接成功了&#xff0c;可直接跳过当我没说&#xff08;不过90%的几率你都会失败的啦&#xff09; 由于http://raw.githubusercontent.com这个网址墙的很厉害&#xff0c;大概率你是成功不了的&#xff0c;这里推荐一种本地化安装的方法…

Docker - 镜像 | 容器 | 数据卷 日常开发常用指令 + 演示(一文通关)

目录 Docker 开发常用指令汇总 辅助命令 docker version docker info docker --help 镜像命令 查看镜像信息 下载镜像 搜索镜像 删除镜像 容器命令 查看运行中的容器 运行容器 停止、启动、重启、暂停、恢复容器 杀死容器 删除容器 查看容器日志 进入容器内部…

理解 Go Mod Init

初始化Go模块和管理依赖的全面指南 go mod init 是Go编程语言&#xff08;通常称为Golang&#xff09;中用于初始化新Go模块的命令。在Go中&#xff0c;一个模块是一组相关的Go包&#xff0c;它们作为一个单元一起进行版本控制。通常&#xff0c;在项目目录的根目录下使用 go m…

Qt之自定义分页(翻页)控件

当数据量较大时,分页显示是个不错的选择。这里用百家姓来演示分页效果,包括首页、上一页、下一页、尾页和跳转。 一.效果 每页15个姓氏。 二.实现 QHPageWidget.h #ifndef QHPAGEWIDGET_H #define QHPAGEWIDGET_H#include <QWidget> #include <QStandardItemMod…

搭建一个高效的Python开发环境

“工欲善其事&#xff0c;必先利其器”&#xff0c;这里我们来搭建一套高效的 Python 开发环境&#xff0c;为后续的数据分析做准备。 关于高效作业&#xff0c;对于需要编写 Python 代码进行数据分析的工作而言&#xff0c;主要涉及两个方面。 1. 一款具备强大的自动完成和错…

Linux多线程服务端编程:线程安全的对象管理

1. 前置知识 1.1 __builtin_expect 1.1.1 使用 __builtin_expect提供给编译器分支预测优化信息&#xff0c;其含义为 exp 大概率为 c&#xff0c;其返回值为 exp 的值&#xff1b; long __builtin_expect(long exp, long c) // 下述表明该分支大概率不会执行 if (__builtin…

【SpringBoot篇】优惠券秒杀 — 添加优惠劵操作(基本操作 | 一人仅一张券的操作)

文章目录 &#x1f354;发放优惠券&#x1f386;基本操作&#x1f384;数据库表&#x1f6f8;思路&#x1f339;代码实现 &#x1f386;完善后的操作&#x1f6f8;乐观锁&#x1f339;代码实现 &#x1f354;一人仅一张优惠券&#x1f6f8;思路&#x1f339;代码⭐代码分析 &am…

Java学习——设计模式——介绍

文章目录 设计模式介绍UML的类图表示类与类之间关系的表示关联关系聚合关系组合关系依赖关系继承关系实现关系 设计模式介绍 设计模式design patterns&#xff0c;指在软件设计中&#xff0c;被反复使用的一种代码设计经验。使用设计模式的目的是为了可重用代码&#xff0c;提…

简单的喷淋实验(2):(1)根据土壤湿度自动控制喷淋开关;(2)根据光照强度控制风扇以及灯的开关---嵌入式实训

目录 简单的喷淋实验(2)&#xff1a; &#xff08;1&#xff09;根据土壤湿度自动控制喷淋开关&#xff1b; &#xff08;2&#xff09;根据光照强度控制风扇以及灯的开关---嵌入式实训 任务2&#xff1a; 具体过程&#xff1a; 所用的头文件&#xff1a; data_global.h …

BDD - Python Behave Retry 机制

BDD - Python Behave Retry 机制 引言Behave RetryBehave Retry 应用feature 文件创建 step 文件Retry运行 Behave 并生成 rerun 文件重新运行失败的场景 引言 在日常运行测试用例&#xff0c;有时因为环境不稳定造成一些测试用例跑失败了&#xff0c;如果能将这些失败的测试用…

少走弯路:单片机使用点阵字体通过像素化的正确获取

要在单片机内自由显示文字&#xff0c;必须准备相应的字库。之前也发文介绍过&#xff1a; 在esp32(esp8266) 提供软字库显示中文的解决方案_esp32中文字库-CSDN博客 包括已经开源的项目&#xff1a; https://github.com/StarCompute/tftziku 这种字体获取思路是&#xff1a…