SpringBoot15 sell02 订单模块
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 订单模块的更多相关文章
- 【JAVAWEB学习笔记】网上商城实战3:购物模块和订单模块
网上商城实战3 今日任务 完成购物模块的功能 完成订单模块的功能 1.1 购物模块: 1.1.1 功能演示: 商品详情: 购物车模块: 1.1.2 代码实现: 1.在商品详情的页 ...
- bookStore第三篇【用户模块、购买模块、订单模块】
用户模块 要登陆后才能购买,因此我们先写购买模块 设计实体 private String id; private String username; private String password; p ...
- 关于正餐智能POS6.0.1.1改版后,订单模块无法进行部分退款的FAQ
适用版本:智能POS正餐V6.0.1.1+ 适用情况:订单模块,无法输入自定义金额进行部分退款. 原因:为让报表统计的数据更准确. 改版之后仍可适用部分退款的情况: 1.口碑先付订单,可在口碑模块,选 ...
- 电子商务(电销)平台中订单模块(Order)数据库设计明细(转)
以下是自己在电子商务系统设计中的订单模块的数据库设计经验总结,而今发表出来一起分享,如有不当,欢迎跟帖讨论~ 订单表 (order)|-- 自动编号(order_id, 自增长主键)|-- 订单单号( ...
- 电子商务(电销)平台中订单模块(Order)数据库设计明细
电子商务(电销)平台中订单模块(Order)数据库设计明细 - sochishun - 博客园 http://www.cnblogs.com/sochishun/p/7040628.html 电子商务 ...
- 【JAVAWEB学习笔记】网上商城实战4:订单模块
今日任务 完成订单模块的功能 1.1 订单 模块的功能 1.1.1 我的订单: [我的订单的查询] * 在header.jsp中点击我的订单. * 提交到Servlet: * 获得用户 ...
- 电子商务(电销)平台中订单模块(Order)数据库设计明细(转载)
电子商务(电销)平台中订单模块(Order)数据库设计明细 以下是自己在电子商务系统设计中的订单模块的数据库设计经验总结,而今发表出来一起分享,如有不当,欢迎跟帖讨论~ 订单表 (order)|-- ...
- Java生鲜电商平台-订单模块状态机架构设计
Java生鲜电商平台-订单模块状态机架构设计 说明:在Java生鲜电商平台中订单的状态流转业务 我们知道 一个订单会有很多种状态:临时单.已下单.待支付.待收货.待评价.已完成,退货中等 ...
- 【笔记6-支付及订单模块】从0开始 独立完成企业级Java电商网站开发(服务端)
支付模块 实际开发工作中经常会遇见如下场景,一个支付模块,一个订单模块,有一定依赖,一个同事负责支付模块,另一个同事负责订单模块,但是开发支付模块的时候要依赖订单模块的相关类 ,方法,或者工具类,这些 ...
随机推荐
- 前端基础之jQuery入门 01
jQuery介绍 jQuery是一个轻量级的.兼容多浏览器的JavaScript库. jQuery使用户能够更方便地处理HTML Document.Events.实现动画效果.方便地进行Ajax交互, ...
- phpcms URL
http://www.jb51.net/cms/112109.html 静态URL生成规则 http://v9.help.phpcms.cn/html/2010/database_1228/107.h ...
- opencv 学习笔记集锦
整理了我所了解的有关OpenCV的学习笔记.原理分析.使用例程等相关的博文.排序不分先后,随机整理的.如果有好的资源,也欢迎介绍和分享. 1:OpenCV学习笔记 作者:CSDN数量:55篇博文网址: ...
- VS2013 快捷方式
1.查找空行: 使用正则表达式 ^\s\S*$\n
- spring源码学习之:springAOP实现底层原理
一:springAOP底层实现是基于动态代理实现的.增强和切面,以及通知.是在动态代理生成的代理类inoke方法中调用实现 //+++++++++++++aop动态代理++++++++++++++++ ...
- vuecli3 运行报错
Microsoft Windows [版本 6.1.7601]版权所有 (c) 2009 Microsoft Corporation.保留所有权利. C:\Users\Administrator\De ...
- poj 3590 The shuffle Problem——DP+置换
题目:http://poj.org/problem?id=3590 bzoj 1025 的弱化版.大概一样的 dp . 输出方案的时候小的环靠前.不用担心 dp 时用 > 还是 >= 来转 ...
- 读写另一EXE的内存
procedure TfrmMain.tmrChangeServerNameTimer(Sender: TObject); function GetProcessID(FileName: string ...
- 在centos6.6中mysql5.5的编译、安装、配置
今天根据需求要在centos6.6上编译安装mysql5.5,因为以前编译安装过感觉很简单,但是今天还是出现了点小问题,所以把过安装过程总结了一下: 好像从mysql5.5开始编译安装mysql需要用 ...
- java代码把字母转换大小写、、、、
总结:从键盘输入多少次,就用for循环控制.这些需要输入的数据都放在循环内部,否则不会执行多次. package com.aaa; import java.util.Scanner; //大小写字母的 ...