1 订单模块

  1.1 MySQL数据表

    订单模块涉及到两个数据表:

      订单表:主要存储订单相关的基本信息

DROP TABLE IF EXISTS `order_master`;
CREATE TABLE `order_master` (
`order_id` varchar(32) NOT NULL,
`buyer_name` varchar(32) NOT NULL COMMENT '买家名字',
`buyer_phone` varchar(32) NOT NULL COMMENT '买家电话',
`buyer_address` varchar(128) NOT NULL COMMENT '买家地址',
`buyer_openid` varchar(64) NOT NULL COMMENT '买家微信openid',
`order_amount` decimal(8,2) NOT NULL COMMENT '订单总金额',
`order_status` tinyint(3) NOT NULL DEFAULT '' COMMENT '订单状态, 默认为新下单',
`pay_status` tinyint(3) NOT NULL DEFAULT '' COMMENT '支付状态, 默认未支付',
`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',
PRIMARY KEY (`order_id`),
KEY `idx_buyer_openid` (`buyer_openid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

order_master

      订单详情表:主要存放和订单相关的shaping详细信息

DROP TABLE IF EXISTS `order_detail`;
CREATE TABLE `order_detail` (
`detail_id` varchar(32) NOT NULL,
`order_id` varchar(32) NOT NULL,
`product_id` varchar(32) NOT NULL,
`product_name` varchar(64) NOT NULL COMMENT '商品名称',
`product_price` decimal(8,2) NOT NULL COMMENT '当前价格,单位分',
`product_quantity` int(11) NOT NULL COMMENT '数量',
`product_icon` varchar(512) DEFAULT NULL COMMENT '小图',
`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',
PRIMARY KEY (`detail_id`),
KEY `idx_order_id` (`order_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

order_detail

  1.2 实体类

    1.2.1 持久实体类

package cn.xiangxu.demo.sell_demo.entity.entityPO;

import com.baomidou.mybatisplus.annotations.TableField;
import lombok.Data; import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
import java.math.BigDecimal;
import java.util.Date; /**
* @author 王杨帅
* @create 2018-04-21 13:33
* @desc 订单实体类
**/
@Table(name = "order_master")
@Data
@Entity
public class OrderMasterPO { /**
* 订单ID
*/
@Id
@Column(name = "order_id")
private String orderId; /**
* 买家名字
*/
@Column(name = "buyer_name")
private String buyerName;
/**
* 买家电话
*/
@Column(name = "buyer_phone")
private String buyerPhone;
/**
* 买家地址
*/
@Column(name = "buyer_address")
private String buyerAddress;
/**
* 买家微信openid
*/
@Column(name = "buyer_openid")
private String buyerOpenid;
/**
* 订单总金额
*/
@Column(name = "order_amount")
private BigDecimal orderAmount;
/**
* 订单状态, 默认为新下单
*/
@Column(name = "order_status")
private Integer orderStatus;
/**
* 支付状态, 默认未支付
*/
@Column(name = "pay_status")
private Integer payStatus;
/**
* 创建时间
*/
@Column(name = "create_time")
private Date createTime;
/**
* 修改时间
*/
@Column(name = "update_time")
private Date updateTime;
}

OrderMasterPO.java

package cn.xiangxu.demo.sell_demo.entity.entityPO;

import lombok.Data;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
import java.math.BigDecimal;
import java.util.Date; /**
* @author 王杨帅
* @create 2018-04-21 13:35
* @desc 订单详情实体类
**/
@Table(name = "order_detail")
@Data
@Entity
public class OrderDetailPO { /**
* 订单详情ID
*/
@Id
@Column(name = "detail_id")
private String detailId;
/**
* 订单ID
*/
@Column(name = "order_id")
private String orderId;
/**
* 产品ID
*/
@Column(name = "product_id")
private String productId;
/**
* 商品名称
*/
@Column(name = "product_name")
private String productName;
/**
* 当前价格,单位分
*/
@Column(name = "product_price")
private BigDecimal productPrice;
/**
* 数量
*/
@Column(name = "product_quantity")
private Integer productQuantity;
/**
* 小图
*/
@Column(name = "product_icon")
private String productIcon;
/**
* 创建时间
*/
@Column(name = "create_time")
private Date createTime;
/**
* 修改时间
*/
@Column(name = "update_time")
private Date updateTime;
}

OrderDetailPO.java

    1.2.2 传输实体类

package cn.xiangxu.demo.sell_demo.entity.entityDTO;

import cn.xiangxu.demo.sell_demo.entity.entityPO.OrderDetailPO;
import lombok.Data; import java.math.BigDecimal;
import java.util.Date;
import java.util.List; /**
* 商品订单和订单详情组合成的数据传输对象
*/
@Data
//@JsonInclude(JsonInclude.Include.NON_NULL) // 数据为null时就不返回
public class OrderDTO {
/** 订单ID */
private String orderId;
/** 买家名字 */
private String buyerName;
/** 买家电话 */
private String buyerPhone;
/** 买家地址 */
private String buyerAddress;
/** 买家微信OpenId */
private String buyerOpenid;
/** 订单金额 */
private BigDecimal orderAmount;
/** 订单状态,默认为0:新下单 */
private Integer orderStatus;
/** 支付状态,默认为0:未支付 */
private Integer payStatus;
/** 创建时间 */
// @JsonSerialize(using = Date2Long.class) // 让毫秒变成秒
private Date createTime;
/** 更新时间 */
// @JsonSerialize(using = Date2Long.class)
private Date updateTime;
/** 订单商品列表 */
List<OrderDetailPO> orderDetailPOList;
}

OrderDTO.java

package cn.xiangxu.demo.sell_demo.entity.entityDTO;

import lombok.Data;

@Data
public class CarDTO { /** 商品ID */
private String productId;
/** 商品数量 */
private Integer productQuantity; public CarDTO() {
} public CarDTO(String productId, Integer productQuantity) {
this.productId = productId;
this.productQuantity = productQuantity;
}
}

CarDTO.java

  1.3 持久层

    1.3.1 订单-master

package cn.xiangxu.demo.sell_demo.dao;

import cn.xiangxu.demo.sell_demo.entity.entityPO.OrderMasterPO;
import org.springframework.data.jpa.repository.JpaRepository; import java.util.List; /**
* @author 王杨帅
* @create 2018-04-21 13:42
* @desc 订单持久层接口
**/
public interface OrderMasterDao extends JpaRepository<OrderMasterPO, String> { /**
* 根据买家的微信OpenId查询订单信息
* @param openId
* @return
*/
List<OrderMasterPO> findByBuyerOpenid(String openId);
}

OrderMasterDao.java

package cn.xiangxu.demo.sell_demo.dao;

import cn.xiangxu.demo.sell_demo.entity.entityPO.OrderMasterPO;
import cn.xiangxu.demo.sell_demo.enums.OrderStatusEnum;
import cn.xiangxu.demo.sell_demo.enums.PayStatusEnum;
import lombok.extern.slf4j.Slf4j;
import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner; import java.math.BigDecimal;
import java.util.List; import static org.junit.Assert.*; @RunWith(SpringRunner.class)
@SpringBootTest
@Slf4j
public class OrderMasterDaoTest { private final String className = getClass().getName(); @Autowired
private OrderMasterDao orderMasterDao; @Test
public void create() { // 01 构建订单对象
OrderMasterPO orderMasterPO = new OrderMasterPO();
orderMasterPO.setOrderId("20180001");
orderMasterPO.setBuyerName("王杨帅");
orderMasterPO.setBuyerPhone("13272885616");
orderMasterPO.setBuyerAddress("广东工业大学");
orderMasterPO.setBuyerOpenid("123456");
orderMasterPO.setOrderAmount(new BigDecimal(333));
orderMasterPO.setOrderStatus(OrderStatusEnum.NEW.getCode());
orderMasterPO.setPayStatus(PayStatusEnum.WAIT.getCode()); // 02 调用持久层对象进行新增操作
OrderMasterPO result = orderMasterDao.save(orderMasterPO); // 03 打印新增结果数据
log.info("===/" + className + "/create===更新后返回的结果为:{}", result);
Assert.assertNotEquals(null, result); } @Test
public void findByBuyerOpenid() throws Exception {
// 01 模拟一个微信openId
String openId = "123456"; // 02 根据微信OpenId查询数据
List<OrderMasterPO> result = orderMasterDao.findByBuyerOpenid(openId); // 03 打印查询到的数据
log.info("===/" + className + "/findByBuyerOpenid===根据微信openId查询到的数据为:{}", result);
} }

OrderMasterDaoTest.java

    1.3.2 订单-detail

package cn.xiangxu.demo.sell_demo.dao;

import cn.xiangxu.demo.sell_demo.entity.entityPO.OrderDetailPO;
import org.springframework.data.jpa.repository.JpaRepository; import java.util.List; /**
* @author 王杨帅
* @create 2018-04-21 13:41
* @desc 订单详情持久层接口
**/
public interface OrderDetailDao extends JpaRepository<OrderDetailPO, String> { /** 根据订单ID查询订单详情信息 */
List<OrderDetailPO> findByOrOrderId(String orderId);
}

OrderDetailDao.java

package cn.xiangxu.demo.sell_demo.dao;

import cn.xiangxu.demo.sell_demo.entity.entityPO.OrderDetailPO;
import lombok.extern.slf4j.Slf4j;
import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner; import java.math.BigDecimal;
import java.util.List; import static org.junit.Assert.*; @RunWith(SpringRunner.class)
@SpringBootTest
@Slf4j
public class OrderDetailDaoTest { private final String className = getClass().getName(); @Autowired
private OrderDetailDao orderDetailDao; @Test
public void create() {
// 01 模拟一个订单详情实例
OrderDetailPO orderDetailPO = new OrderDetailPO();
orderDetailPO.setDetailId("2");
orderDetailPO.setOrderId("20180001");
orderDetailPO.setProductId("20180001");
orderDetailPO.setProductName("皮蛋粥");
orderDetailPO.setProductPrice(new BigDecimal(3.5));
orderDetailPO.setProductQuantity(3);
orderDetailPO.setProductIcon("http://xxasd.com"); // 02 执行新增操作
OrderDetailPO result = orderDetailDao.save(orderDetailPO); // 03 返回结果
log.info("===/" + className + "/create===新增后的返回数据为:{}", result);
Assert.assertNotEquals(null, result);
} @Test
public void findByOrOrderId() throws Exception {
// 模拟一个订单ID
String orderId = "20180001"; // 根据订单ID进行查询
List<OrderDetailPO> result = orderDetailDao.findByOrOrderId(orderId); // 记录查询结果
log.info("===/" + className + "/findByOrderId===根据订单ID查询到的数据为:{}", result);
Assert.assertNotEquals(0, result.size());
} }

OrderDetailDaoTest.java

  

      

SpringBoot15 sell02 订单模块的更多相关文章

  1. 【JAVAWEB学习笔记】网上商城实战3:购物模块和订单模块

    网上商城实战3 今日任务 完成购物模块的功能 完成订单模块的功能 1.1      购物模块: 1.1.1    功能演示: 商品详情: 购物车模块: 1.1.2    代码实现: 1.在商品详情的页 ...

  2. bookStore第三篇【用户模块、购买模块、订单模块】

    用户模块 要登陆后才能购买,因此我们先写购买模块 设计实体 private String id; private String username; private String password; p ...

  3. 关于正餐智能POS6.0.1.1改版后,订单模块无法进行部分退款的FAQ

    适用版本:智能POS正餐V6.0.1.1+ 适用情况:订单模块,无法输入自定义金额进行部分退款. 原因:为让报表统计的数据更准确. 改版之后仍可适用部分退款的情况: 1.口碑先付订单,可在口碑模块,选 ...

  4. 电子商务(电销)平台中订单模块(Order)数据库设计明细(转)

    以下是自己在电子商务系统设计中的订单模块的数据库设计经验总结,而今发表出来一起分享,如有不当,欢迎跟帖讨论~ 订单表 (order)|-- 自动编号(order_id, 自增长主键)|-- 订单单号( ...

  5. 电子商务(电销)平台中订单模块(Order)数据库设计明细

    电子商务(电销)平台中订单模块(Order)数据库设计明细 - sochishun - 博客园 http://www.cnblogs.com/sochishun/p/7040628.html 电子商务 ...

  6. 【JAVAWEB学习笔记】网上商城实战4:订单模块

    今日任务 完成订单模块的功能 1.1      订单 模块的功能 1.1.1    我的订单: [我的订单的查询] * 在header.jsp中点击我的订单. * 提交到Servlet: * 获得用户 ...

  7. 电子商务(电销)平台中订单模块(Order)数据库设计明细(转载)

    电子商务(电销)平台中订单模块(Order)数据库设计明细 以下是自己在电子商务系统设计中的订单模块的数据库设计经验总结,而今发表出来一起分享,如有不当,欢迎跟帖讨论~ 订单表 (order)|-- ...

  8. Java生鲜电商平台-订单模块状态机架构设计

    Java生鲜电商平台-订单模块状态机架构设计 说明:在Java生鲜电商平台中订单的状态流转业务        我们知道 一个订单会有很多种状态:临时单.已下单.待支付.待收货.待评价.已完成,退货中等 ...

  9. 【笔记6-支付及订单模块】从0开始 独立完成企业级Java电商网站开发(服务端)

    支付模块 实际开发工作中经常会遇见如下场景,一个支付模块,一个订单模块,有一定依赖,一个同事负责支付模块,另一个同事负责订单模块,但是开发支付模块的时候要依赖订单模块的相关类 ,方法,或者工具类,这些 ...

随机推荐

  1. C# 自定义exe引用的dll路径

    MSDN原文:https://msdn.microsoft.com/library/twy1dw1e(v=vs.100).aspx <runtime> 的 <assemblyBind ...

  2. 解决direct2d拖拽窗口闪烁

    响应WM_ERASEBKGND,在OnEraseBkgnd()处返回FALSE,阻止GDI重绘客户区背景色,设置背景色的工作交给Direct2D在Render时设置,否则在Resize时会出现窗口闪烁 ...

  3. Spring IOC容器在Web容器中是怎样启动的

    前言 我们一般都知道怎样使用spring来开发web应用后,但对spring的内部实现机制通常不是很明白.这里从源码角度分析下Spring是怎样启动的.在讲spring启动之前,我们先来看看一个web ...

  4. RabbitMQ之Consumer消费模式(Push & Pull)

    版权声明:本文为博主原创文章,未经博主朱小厮允许不得转载. https://blog.csdn.net/u013256816/article/details/62890189概述消息中间件有很多种,进 ...

  5. Notepad++如何取消打开最近的历史文件

    1.设置 2.首选项 3.备份 4.取消勾选 "Remember current session for next launch" 5.重新启动即可. 出处:http://www. ...

  6. css学习笔记之图像

    图像与文本的对齐方式: vertical-align:text-top;表示的意思是图像的顶部和同一行的文本对齐,但文本不会超出图片的上边线. vertical-align:middle;表示的意思是 ...

  7. android中MediaPlayer类的用法

    用法直接看sample package com.turtle920.androidaudioprocess; import android.media.MediaPlayer; import andr ...

  8. 安装nagios-plugins插件make时遇到的error

    安装nagios-plugins插件make时遇到的error error内容: check_http.c: In function ‘process_arguments’: check_http.c ...

  9. saas服务提供商

    这段时间接触了不少行业的东西,这里谈几点肤浅的看法.从市场行情上讲,SaaS风口还在,不过热度明显向大数据.物联网.人工智能.区块链等转移. 做得比较好的有这些SaaS提供商,每个领域的都有那么几家的 ...

  10. 全文检索引擎Solr系列——Solr核心概念、配置文件

    Document Document是Solr索引(动词,indexing)和搜索的最基本单元,它类似于关系数据库表中的一条记录,可以包含一个或多个字段(Field),每个字段包含一个name和文本值. ...