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电商网站开发(服务端)
支付模块 实际开发工作中经常会遇见如下场景,一个支付模块,一个订单模块,有一定依赖,一个同事负责支付模块,另一个同事负责订单模块,但是开发支付模块的时候要依赖订单模块的相关类 ,方法,或者工具类,这些 ...
随机推荐
- PTA L3-023 计算图 (dfs+数学推导)
“计算图”(computational graph)是现代深度学习系统的基础执行引擎,提供了一种表示任意数学表达式的方法,例如用有向无环图表示的神经网络. 图中的节点表示基本操作或输入变量,边表示节点 ...
- CodeForces - 622F:The Sum of the k-th Powers (拉格朗日插值法求自然数幂和)
There are well-known formulas: , , . Also mathematicians found similar formulas for higher degrees. ...
- HDU3507Print Article (斜率优化DP)
Zero has an old printer that doesn't work well sometimes. As it is antique, he still like to use it ...
- NET Core中使用MediatR实现命令和中介者模式
NET Core中使用MediatR实现命令和中介者模式 https://www.cnblogs.com/yilezhu/p/9866068.html 在本文中,我将解释命令模式,以及如何利用基于命令 ...
- ERP与MES
EAS-ERP企业资源计划系统 能将企业的客户管理.商品管理.采购管理.仓储管理.销售管理.生产管理.应收应付.财务管理.工资管理.费用管理和业绩考核管理以及业务预警和全方位的分析汇总融为一体,为企业 ...
- 【JQuery】学习
JavaScript参考 JQuery 学习总结及实例 1.JQuery概念 A.Jquery是一个优秀的Javascript框架.它是轻量级的js库 ,它兼容CSS3,还兼容各种浏览器,jQuery ...
- Java各种集合容器的总结
Java容器指的是List,Set,Map这些类.由于翻译的问题,问到集合,Collection这些指的都是它们几个. List ArrayList 随机访问快 LinkedList 插入删除快 这个 ...
- asp select count(*) 用 open还是excute
dSql1="select count(*) from test_hist where uid="&cid 'dRs1.open dSql1,tConn,1,1 'dS ...
- ODBC、OLEDB、ADO、SQL的关系
对于一个刚接触数据库的菜鸟来说(比如我),总是搞不清SQL.ADO.OLE DB.ODBC,大脑中一片混乱,好像懂了,又好像没懂,非常的苦恼,今天下了点功夫研究了一下,贴出来,其中肯定有好多错误,希望 ...
- unittest框架+ HTMLTestRunner 出报告时,展示控制台信息 不同展示的参数写法 加verbosity
加verbosity参数 没有加的时候展示: 参考: 来源: https://www.cnblogs.com/tomweng/p/6609937.html 介绍: HTMLTestRunner 是 ...