From f4c7f65cb8aa9764a6e47f18535929cd37605fa5 Mon Sep 17 00:00:00 2001 From: sin <2943460818@qq.com> Date: Fri, 22 Mar 2019 21:51:55 +0800 Subject: [PATCH] =?UTF-8?q?-=20=E5=A2=9E=E5=8A=A0=20OrderLogisticsMapper?= =?UTF-8?q?=20-=20=E4=BF=AE=E6=94=B9=20OrderServiceImpl=20=E8=AE=A2?= =?UTF-8?q?=E5=8D=95=E5=88=9B=E5=BB=BA=E5=92=8C=E5=88=A0=E9=99=A4=20-=20?= =?UTF-8?q?=E4=BF=AE=E6=94=B9=20=E8=AE=A2=E5=8D=95=E7=9A=84=E8=A1=A8?= =?UTF-8?q?=E7=BB=93=E6=9E=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../mall/order/dao/OrderLogisticsMapper.java | 22 ++++ .../mall/order/dataobject/OrderDO.java | 26 +--- .../order/dataobject/OrderExchangeDO.java | 46 +++++-- .../mall/order/dataobject/OrderItemDO.java | 61 +++------ .../dataobject/OrderLogisticsDetailDO.java | 14 -- .../mall/order/dataobject/OrderReturnDO.java | 14 ++ .../mall/order/service/OrderServiceImpl.java | 59 +++++++-- .../resources/mapper/OrderLogisticsMapper.xml | 21 +++ .../src/main/resources/mapper/OrderMapper.xml | 58 +++++---- .../src/main/resources/sql/mall_order.sql | 121 ++++++++++++++++++ 10 files changed, 305 insertions(+), 137 deletions(-) create mode 100644 order/order-service-impl/src/main/java/cn/iocoder/mall/order/dao/OrderLogisticsMapper.java create mode 100644 order/order-service-impl/src/main/resources/mapper/OrderLogisticsMapper.xml create mode 100644 order/order-service-impl/src/main/resources/sql/mall_order.sql diff --git a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dao/OrderLogisticsMapper.java b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dao/OrderLogisticsMapper.java new file mode 100644 index 00000000..b72e6dc8 --- /dev/null +++ b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dao/OrderLogisticsMapper.java @@ -0,0 +1,22 @@ +package cn.iocoder.mall.order.dao; + +import cn.iocoder.mall.order.dataobject.OrderDO; +import cn.iocoder.mall.order.dataobject.OrderLogisticsDO; +import org.springframework.stereotype.Repository; + +/** + * è®¢å• item mapper + * + * @author Sin + * @time 2019-03-16 15:09 + */ +@Repository +public interface OrderLogisticsMapper { + + /** + * æ’å…¥æ•°æ® + * + * @param orderLogisticsDO + */ + void insert(OrderLogisticsDO orderLogisticsDO); +} diff --git a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderDO.java b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderDO.java index ba3a9014..a318766d 100644 --- a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderDO.java +++ b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderDO.java @@ -2,7 +2,6 @@ package cn.iocoder.mall.order.dataobject; import cn.iocoder.common.framework.dataobject.BaseDO; -import java.io.Serializable; import java.util.Date; /** @@ -34,19 +33,19 @@ public class OrderDO extends BaseDO { /// æ—¶é—´ä¿¡æ¯ /** - * 付款时间 + * 付款时间(待å‘货) */ private Date paymentTime; /** - * å‘è´§æ—¶é—´ + * å‘货时间(待收货) */ private Date deliveryTime; /** - * æ”¶è´§æ—¶é—´ + * æ”¶è´§æ—¶é—´ï¼ˆå·²ç¾æ”¶ï¼‰ */ private Date receiverTime; /** - * æˆäº¤æ—¶é—´ + * æˆäº¤æ—¶é—´ï¼ˆç”¨æˆ·ç¡®è®¤æ”¶è´§ -> status = 已完æˆï¼‰ */ private Date closingTime; @@ -72,13 +71,6 @@ public class OrderDO extends BaseDO { * - 4ã€å·²å…³é— */ private Integer status; - /** - * åˆ é™¤çŠ¶æ€ - * - * - 0 æœªåˆ é™¤ - * - 1 å·²åˆ é™¤ - */ - private Integer deleteStatus; /** * 备注 */ @@ -97,7 +89,6 @@ public class OrderDO extends BaseDO { ", closingTime=" + closingTime + ", hasReturnExchange=" + hasReturnExchange + ", status=" + status + - ", deleteStatus=" + deleteStatus + ", remark='" + remark + '\'' + '}'; } @@ -192,15 +183,6 @@ public class OrderDO extends BaseDO { return this; } - public Integer getDeleteStatus() { - return deleteStatus; - } - - public OrderDO setDeleteStatus(Integer deleteStatus) { - this.deleteStatus = deleteStatus; - return this; - } - public String getRemark() { return remark; } diff --git a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderExchangeDO.java b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderExchangeDO.java index f01e392e..bc22e0ff 100644 --- a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderExchangeDO.java +++ b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderExchangeDO.java @@ -24,6 +24,10 @@ public class OrderExchangeDO extends BaseDO { * 订å•ç¼–å· */ private String orderNo; + /** + * è®¢å• item ç¼–å· + */ + private Integer orderItemId; /** * 商å“id(ä¿å˜ä¸€ä¸ªå†—余,如果一个订å•下å˜åœ¨å¤šä¸ªå•†å“,会有很大的作用) */ @@ -62,8 +66,9 @@ public class OrderExchangeDO extends BaseDO { /** * 创建时间 + * supper baseDO */ - private Date createTime; +// private Date createTime; /** * 付款时间 */ @@ -84,6 +89,13 @@ public class OrderExchangeDO extends BaseDO { /// /// å…¶ä»– + /** + * 订å•类型 + * + * - 0ã€ä¸º Order è®¢å• ï¼ˆå¯¹æ•´ä¸ªè®¢å•退货) + * - 1ã€ä¸º OrderItem è®¢å• ï¼ˆå¯¹è®¢å•æŸä¸€ä¸ªå•†å“退货) + */ + private Integer orderType; /** * çŠ¶æ€ * @@ -101,17 +113,18 @@ public class OrderExchangeDO extends BaseDO { "id=" + id + ", orderId=" + orderId + ", orderNo='" + orderNo + '\'' + + ", orderItemId=" + orderItemId + ", skuId='" + skuId + '\'' + ", exchangeSkuId='" + exchangeSkuId + '\'' + ", exchangeOrderLogisticsId=" + exchangeOrderLogisticsId + ", receiverOrderLogisticsId=" + receiverOrderLogisticsId + ", orderReasonId=" + orderReasonId + ", reason='" + reason + '\'' + - ", createTime=" + createTime + ", paymentTime=" + paymentTime + ", deliveryTime=" + deliveryTime + ", receiverTime=" + receiverTime + ", closingTime=" + closingTime + + ", orderType=" + orderType + ", status=" + status + '}'; } @@ -143,6 +156,15 @@ public class OrderExchangeDO extends BaseDO { return this; } + public Integer getOrderItemId() { + return orderItemId; + } + + public OrderExchangeDO setOrderItemId(Integer orderItemId) { + this.orderItemId = orderItemId; + return this; + } + public String getSkuId() { return skuId; } @@ -197,17 +219,6 @@ public class OrderExchangeDO extends BaseDO { return this; } - @Override - public Date getCreateTime() { - return createTime; - } - - @Override - public OrderExchangeDO setCreateTime(Date createTime) { - this.createTime = createTime; - return this; - } - public Date getPaymentTime() { return paymentTime; } @@ -244,6 +255,15 @@ public class OrderExchangeDO extends BaseDO { return this; } + public Integer getOrderType() { + return orderType; + } + + public OrderExchangeDO setOrderType(Integer orderType) { + this.orderType = orderType; + return this; + } + public Integer getStatus() { return status; } diff --git a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderItemDO.java b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderItemDO.java index 7c463e7f..70dae0cd 100644 --- a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderItemDO.java +++ b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderItemDO.java @@ -40,10 +40,6 @@ public class OrderItemDO extends BaseDO { /// /// æ—¶é—´ä¿¡æ¯ - /** - * 创建时间 - */ - private Date createTime; /** * 付款时间 */ @@ -67,25 +63,20 @@ public class OrderItemDO extends BaseDO { /** * 是å¦é€€è´§ * - * - 0ã€no - * - 1ã€yes - */ - private Integer hasReturn; - /** - * æ˜¯å¦æ¢è´§ - * - * - 0ã€no - * - 1ã€yes + * - 1ã€æ²¡æœ‰ + * - 2ã€æ¢è´§ + * - 3ã€é€€è´§ + * - 4ã€æ¢è´§ + 退货 */ - private Integer hasExchange; + private Integer hasReturnExchange; /** * çŠ¶æ€ * - * - 0ã€å¾…付款 - * - 1ã€å¾…å‘è´§ - * - 2ã€å¾…收获 - * - 3ã€å·²å®Œæˆ - * - 4ã€å·²å…³é— + * - 1ã€å¾…付款 + * - 2ã€å¾…å‘è´§ + * - 3ã€å·²å‘è´§ + * - 4ã€å·²å®Œæˆ + * - 5ã€å·²å…³é— */ private Integer status; @@ -98,13 +89,11 @@ public class OrderItemDO extends BaseDO { ", skuId='" + skuId + '\'' + ", quantity=" + quantity + ", price=" + price + - ", createTime=" + createTime + ", paymentTime=" + paymentTime + ", deliveryTime=" + deliveryTime + ", receiverTime=" + receiverTime + ", closingTime=" + closingTime + - ", hasReturn=" + hasReturn + - ", hasExchange=" + hasExchange + + ", hasReturnExchange=" + hasReturnExchange + ", status=" + status + '}'; } @@ -163,17 +152,6 @@ public class OrderItemDO extends BaseDO { return this; } - @Override - public Date getCreateTime() { - return createTime; - } - - @Override - public OrderItemDO setCreateTime(Date createTime) { - this.createTime = createTime; - return this; - } - public Date getPaymentTime() { return paymentTime; } @@ -210,21 +188,12 @@ public class OrderItemDO extends BaseDO { return this; } - public Integer getHasReturn() { - return hasReturn; - } - - public OrderItemDO setHasReturn(Integer hasReturn) { - this.hasReturn = hasReturn; - return this; - } - - public Integer getHasExchange() { - return hasExchange; + public Integer getHasReturnExchange() { + return hasReturnExchange; } - public OrderItemDO setHasExchange(Integer hasExchange) { - this.hasExchange = hasExchange; + public OrderItemDO setHasReturnExchange(Integer hasReturnExchange) { + this.hasReturnExchange = hasReturnExchange; return this; } diff --git a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderLogisticsDetailDO.java b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderLogisticsDetailDO.java index 6e461b45..0e3bf479 100644 --- a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderLogisticsDetailDO.java +++ b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderLogisticsDetailDO.java @@ -30,10 +30,6 @@ public class OrderLogisticsDetailDO extends BaseDO { * 物æµä¿¡æ¯ */ private String logisticsInformation; - /** - * åˆ›å»ºæ—¶é—´ï¼ˆåŒæ¥æ—¶é—´ï¼‰ - */ - private Date createTime; @Override public String toString() { @@ -42,7 +38,6 @@ public class OrderLogisticsDetailDO extends BaseDO { ", orderLogisticsId=" + orderLogisticsId + ", logisticsTime=" + logisticsTime + ", logisticsInformation='" + logisticsInformation + '\'' + - ", createTime=" + createTime + '}'; } @@ -81,13 +76,4 @@ public class OrderLogisticsDetailDO extends BaseDO { this.logisticsInformation = logisticsInformation; return this; } - - public Date getCreateTime() { - return createTime; - } - - public OrderLogisticsDetailDO setCreateTime(Date createTime) { - this.createTime = createTime; - return this; - } } diff --git a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderReturnDO.java b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderReturnDO.java index 3e6714d8..7a0088f7 100644 --- a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderReturnDO.java +++ b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/dataobject/OrderReturnDO.java @@ -32,6 +32,10 @@ public class OrderReturnDO extends BaseDO { * 商å“ç¼–å·ï¼ˆä¿å˜ä¸€ä¸ªå†—余,如果一个订å•下å˜åœ¨å¤šä¸ªå•†å“,会有很大的作用) */ private String skuId; + /** + * 物æµid + */ + private Integer orderLogisticsId; /// /// é€€è´§åŽŸå› @@ -102,6 +106,7 @@ public class OrderReturnDO extends BaseDO { ", orderNo='" + orderNo + '\'' + ", orderItemId=" + orderItemId + ", skuId='" + skuId + '\'' + + ", orderLogisticsId=" + orderLogisticsId + ", orderReasonId=" + orderReasonId + ", reason='" + reason + '\'' + ", createTime=" + createTime + @@ -159,6 +164,15 @@ public class OrderReturnDO extends BaseDO { return this; } + public Integer getOrderLogisticsId() { + return orderLogisticsId; + } + + public OrderReturnDO setOrderLogisticsId(Integer orderLogisticsId) { + this.orderLogisticsId = orderLogisticsId; + return this; + } + public Integer getOrderReasonId() { return orderReasonId; } diff --git a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/service/OrderServiceImpl.java b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/service/OrderServiceImpl.java index 974657db..5a8d6626 100644 --- a/order/order-service-impl/src/main/java/cn/iocoder/mall/order/service/OrderServiceImpl.java +++ b/order/order-service-impl/src/main/java/cn/iocoder/mall/order/service/OrderServiceImpl.java @@ -1,27 +1,30 @@ package cn.iocoder.mall.order.service; +import cn.iocoder.common.framework.constant.DeleteStatusEnum; import cn.iocoder.mall.order.api.OrderService; import cn.iocoder.mall.order.api.bo.OrderBO; -import cn.iocoder.mall.order.api.constants.OrderDeleteStatusEnum; -import cn.iocoder.mall.order.api.constants.OrderPayStatusEnum; -import cn.iocoder.mall.order.api.constants.OrderStatusEnum; +import cn.iocoder.mall.order.api.constant.OrderHasReturnExchangeEnum; +import cn.iocoder.mall.order.api.constant.OrderStatusEnum; import cn.iocoder.mall.order.api.dto.OrderCreateDTO; import cn.iocoder.mall.order.api.dto.OrderCreateItemDTO; import cn.iocoder.mall.order.api.dto.OrderReceiverInformationDTO; import cn.iocoder.mall.order.api.dto.OrderUpdateDTO; import cn.iocoder.mall.order.convert.OrderConvert; import cn.iocoder.mall.order.dao.OrderItemMapper; +import cn.iocoder.mall.order.dao.OrderLogisticsMapper; import cn.iocoder.mall.order.dao.OrderMapper; import cn.iocoder.mall.order.dataobject.OrderDO; import cn.iocoder.mall.order.dataobject.OrderItemDO; -import org.checkerframework.checker.units.qual.A; +import cn.iocoder.mall.order.dataobject.OrderLogisticsDO; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.Date; import java.util.List; +import java.util.Optional; import java.util.UUID; +import java.util.concurrent.atomic.AtomicInteger; /** * è®¢å• service impl @@ -37,39 +40,67 @@ public class OrderServiceImpl implements OrderService { private OrderMapper orderMapper; @Autowired private OrderItemMapper orderItemMapper; + @Autowired + private OrderLogisticsMapper orderLogisticsMapper; @Override @Transactional public OrderBO createOrder(OrderCreateDTO orderCreateDTO) { List<OrderCreateItemDTO> orderItemDTOList = orderCreateDTO.getOrderItems(); - OrderDO orderDO = OrderConvert.INSTANCE.convert(orderCreateDTO); + OrderLogisticsDO orderLogisticsDO = OrderConvert.INSTANCE.convert(orderCreateDTO); List<OrderItemDO> orderItemDOList = OrderConvert.INSTANCE.convert(orderItemDTOList); + // 物æµä¿¡æ¯ + orderLogisticsDO.setLogisticsNo(""); + orderLogisticsMapper.insert(orderLogisticsDO); + // order + OrderDO orderDO = new OrderDO(); + orderDO.setOrderLogisticsId(orderLogisticsDO.getId()); orderDO.setOrderNo(UUID.randomUUID().toString().replace("-", "")); - orderDO.setPrice(1000); + orderDO.setPrice(-1); // 先设置一个默认值,金é¢åœ¨ä¸‹é¢è®¡ç®— orderDO.setCreateTime(new Date()); + orderDO.setUpdateTime(null); + orderDO.setDeleted(DeleteStatusEnum.DELETE_NO.getValue()); + orderDO.setClosingTime(null); orderDO.setDeliveryTime(null); orderDO.setPaymentTime(null); orderDO.setStatus(OrderStatusEnum.WAIT_SHIPMENT.getValue()); - orderDO.setPayStatus(OrderPayStatusEnum.WAITING_PAYMENT.getValue()); - orderDO.setDeleteStatus(OrderDeleteStatusEnum.DELETE_NO.getValue()); + orderDO.setHasReturnExchange(OrderHasReturnExchangeEnum.NO.getValue()); + orderDO.setRemark(Optional.ofNullable(orderCreateDTO.getRemark()).orElse("")); orderMapper.insert(orderDO); // order item - int goodsPrice = 1000; + AtomicInteger totalPrice = new AtomicInteger(); orderItemDOList.forEach(orderItemDO -> { + int goodsPrice = 1000; // 商å“å•ä»· int price = orderItemDO.getQuantity() * goodsPrice; + totalPrice.addAndGet(price); orderItemDO - .setStatus(OrderStatusEnum.WAIT_SHIPMENT.getValue()) .setOrderId(orderDO.getId()) - .setPrice(price) - .setDeliveryTime(null); + .setOrderNo(orderDO.getOrderNo()) + .setPrice(goodsPrice) + .setPaymentTime(null) + .setDeliveryTime(null) + .setReceiverTime(null) + .setClosingTime(null) + .setHasReturnExchange(OrderStatusEnum.WAITING_PAYMENT.getValue()) + .setStatus(OrderStatusEnum.WAITING_PAYMENT.getValue()) + .setCreateTime(new Date()) + .setUpdateTime(new Date()) + .setDeleted(DeleteStatusEnum.DELETE_NO.getValue()); orderItemMapper.insert(orderItemDO); }); + // 更新订å•é‡‘é¢ + orderMapper.updateById( + new OrderDO() + .setId(orderDO.getId()) + .setPrice(totalPrice.get()) + ); + // TODO: 2019-03-17 Sin 需è¦å‘é€ åˆ›å»ºæˆæžœ MQ æ¶ˆæ¯ return new OrderBO() @@ -93,9 +124,9 @@ public class OrderServiceImpl implements OrderService { @Override public void deleteOrder(Integer id) { // åˆ é™¤è®¢å•æ“作,一般用于 ç”¨æˆ·ç«¯åˆ é™¤ï¼Œæ˜¯å¦å˜åœ¨æ£€æŸ¥å¯ä»¥è¿‡æŽ‰ - orderMapper.updateById(new OrderDO() + orderMapper.updateById((OrderDO) new OrderDO() .setId(id) - .setDeleteStatus(OrderDeleteStatusEnum.DELETE_YES.getValue()) + .setDeleted(DeleteStatusEnum.DELETE_YES.getValue()) ); } diff --git a/order/order-service-impl/src/main/resources/mapper/OrderLogisticsMapper.xml b/order/order-service-impl/src/main/resources/mapper/OrderLogisticsMapper.xml new file mode 100644 index 00000000..ad3bedb8 --- /dev/null +++ b/order/order-service-impl/src/main/resources/mapper/OrderLogisticsMapper.xml @@ -0,0 +1,21 @@ +<?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="cn.iocoder.mall.order.dao.OrderLogisticsMapper"> + + <sql id="FIELDS"> + id, area_no, `name`, mobile, address, logistics_no + </sql> + + <!-- + æ’å…¥æ•°æ® + --> + <insert id="insert" parameterType="OrderLogisticsDO" useGeneratedKeys="true" keyColumn="id" keyProperty="id"> + INSERT INTO `order_logistics` ( + area_no, `name`, mobile, address, logistics_no + ) VALUES ( + #{areaNo}, #{name}, #{mobile}, #{address}, + #{logisticsNo} + ) + </insert> + +</mapper> \ No newline at end of file diff --git a/order/order-service-impl/src/main/resources/mapper/OrderMapper.xml b/order/order-service-impl/src/main/resources/mapper/OrderMapper.xml index a1ac6d96..254e7ec4 100644 --- a/order/order-service-impl/src/main/resources/mapper/OrderMapper.xml +++ b/order/order-service-impl/src/main/resources/mapper/OrderMapper.xml @@ -3,9 +3,9 @@ <mapper namespace="cn.iocoder.mall.order.dao.OrderMapper"> <sql id="FIELDS"> - order_no, price, receiver_area_no, receiver_mobile, - receiver_address, `status`, pay_status, create_time, - payment_time, delivery_time, closing_time, remark + id, order_logistics_id, order_no, price, payment_time, + delivery_time, receiver_time, closing_time, has_return_exchange, + status, remark </sql> <!-- @@ -13,13 +13,13 @@ --> <insert id="insert" parameterType="OrderDO" useGeneratedKeys="true" keyColumn="id" keyProperty="id"> INSERT INTO `order` ( - order_no, price, receiver_area_no, receiver_mobile, - receiver_address, `status`, pay_status, create_time, - payment_time, delivery_time, closing_time, remark + order_logistics_id, order_no, price, payment_time, + delivery_time, receiver_time, closing_time, + has_return_exchange, status, remark ) VALUES ( - #{orderNo}, ${price}, #{receiverAreaNo}, #{receiverMobile}, - #{receiverAddress}, #{status}, #{payStatus}, #{createTime}, - #{paymentTime}, #{deliveryTime}, #{closingTime}, #{remark} + #{orderLogisticsId}, ${orderNo}, #{price}, #{paymentTime}, + #{deliveryTime}, #{receiverTime}, #{closingTime}, + #{hasReturnExchange}, #{status}, #{remark} ) </insert> @@ -28,41 +28,43 @@ --> <sql id="updateSql" > <set> + <if test="orderLogisticsId != null"> + , order_logistics_id = #{orderLogisticsId} + </if> <if test="orderNo != null"> , order_no = #{orderNo} </if> <if test="price != null"> , price = #{price} </if> - <if test="receiverAreaNo != null"> - , receiver_area_no = #{receiverAreaNo} +-- time + <if test="paymentTime != null"> + , payment_time = #{paymentTime} </if> - <if test="receiverMobile != null"> - , receiver_mobile = #{receiverMobile} + <if test="deliveryTime != null"> + , delivery_time = #{deliveryTime} + </if> + <if test="receiverTime != null"> + , receiver_time = #{receiverTime} + </if> + <if test="closingTime != null"> + , closing_time = #{closingTime} </if> - <if test="receiverAddress != null"> - , receiver_address = #{receiverAddress} + <if test="hasReturnExchange != null"> + , has_return_exchange = #{hasReturnExchange} </if> +-- other <if test="status != null"> , status = #{status} </if> - <if test="payStatus != null"> - , pay_status = #{payStatus} - </if> - <if test="deleteStatus != null"> - , delete_status = #{deleteStatus} + <if test="delete != null"> + , `delete` = #{delete} </if> <if test="createTime != null"> , create_time = #{createTime} </if> - <if test="paymentTime != null"> - , payment_time = #{paymentTime} - </if> - <if test="deliveryTime != null"> - , delivery_time = #{deliveryTime} - </if> - <if test="closingTime != null"> - , closing_time = #{closingTime} + <if test="updateTime != null"> + , update_time = #{updateTime} </if> <if test="remark != null"> , remark = #{remark} diff --git a/order/order-service-impl/src/main/resources/sql/mall_order.sql b/order/order-service-impl/src/main/resources/sql/mall_order.sql new file mode 100644 index 00000000..4683263a --- /dev/null +++ b/order/order-service-impl/src/main/resources/sql/mall_order.sql @@ -0,0 +1,121 @@ +DROP TABLE `order`; +DROP TABLE `order_item`; +DROP TABLE `order_exchange`; +DROP TABLE `order_return`; +DROP TABLE `order_logistics`; +DROP TABLE `order_logistics_detail`; + +CREATE TABLE `order` ( +`id` int NOT NULL AUTO_INCREMENT COMMENT 'Id,自增长', +`order_logistics_id` int NOT NULL COMMENT '物æµid', +`order_no` varchar(50) NOT NULL COMMENT '订å•å•å·', +`price` int(10) NULL COMMENT '金é¢(分)', +`payment_time` datetime NULL COMMENT '付款时间', +`delivery_time` datetime NULL COMMENT 'å‘è´§æ—¶é—´', +`receiver_time` datetime NULL COMMENT 'æ”¶è´§æ—¶é—´', +`closing_time` datetime NULL COMMENT 'æˆäº¤æ—¶é—´', +`has_return_exchange` smallint NULL COMMENT '是å¦é€€æ¢è´§', +`remark` varchar(255) NULL COMMENT '备注', +`status` smallint(2) NULL COMMENT '状æ€(如果有多个商å“分开å‘货需è¦å…¨éƒ¨å•†å“å‘完æ‰ä¼šæ”¹å˜çжæ€) 0ã€å¾…付款 1ã€å¾…å‘è´§ 2ã€å¾…æ”¶è´§ 3ã€å·²å®Œæˆ 4ã€å·²å…³é—', +`create_time` datetime NULL COMMENT '订å•创建时间', +`update_time` datetime NULL COMMENT 'æ›´æ–°æ—¶é—´', +`deleted` smallint NULL COMMENT 'åˆ é™¤çŠ¶æ€', +PRIMARY KEY (`id`) +); +CREATE TABLE `order_item` ( +`id` int NOT NULL AUTO_INCREMENT COMMENT 'id自增长', +`order_id` int NOT NULL COMMENT '订å•ç¼–å·', +`order_no` varchar(50) NOT NULL COMMENT '订å•å·', +`sku_id` int NOT NULL COMMENT '商å“ç¼–å·', +`quantity` int(3) NOT NULL COMMENT '商哿•°é‡', +`price` int(255) NOT NULL COMMENT '金é¢', +`payment_time` datetime NULL COMMENT '付款时间', +`delivery_time` datetime NULL COMMENT 'å‘è´§æ—¶é—´', +`receiver_time` datetime NULL COMMENT 'æ”¶è´§æ—¶é—´', +`closing_time` datetime NULL, +`has_return_exchange` int NULL COMMENT '是å¦é€€æ¢è´§', +`create_time` datetime NULL COMMENT '创建时间', +`update_time` datetime NULL COMMENT 'æ›´æ–°æ—¶é—´', +`status` smallint(2) NOT NULL COMMENT '状æ€ï¼š0ã€ä»£å‘è´§ 1ã€å·²å‘è´§ 2ã€å·²æ”¶è´§ 20ã€æ¢è´§ä¸ 21ã€æ¢è´§æˆåŠŸ 40ã€é€€è´§ä¸ 41ã€å·²é€€è´§', +`delete` smallint(2) NOT NULL COMMENT 'åˆ é™¤çŠ¶æ€', +PRIMARY KEY (`id`) +); + +CREATE TABLE `order_exchange` ( +`id` int(11) NOT NULL AUTO_INCREMENT, +`order_id` int(11) NOT NULL, +`order_no` varchar(50) NOT NULL, +`sku_id` int(11) NOT NULL, +`exchange_sku_id` int(11) NOT NULL COMMENT 'æ¢è´§å•†å“id', +`exchange_order_logistics_id` int(11) NOT NULL COMMENT 'æ¢è´§ç‰©æµid', +`receiver_order_logistics_id` int(11) NOT NULL COMMENT '收件地å€', +`order_reason_id` int(11) NULL COMMENT 'æ¢è´§åŽŸå› ', +`reason` varchar(255) NULL COMMENT 'æ¢è´§åŽŸå› (其他的时候)', +`payment_time` datetime NULL COMMENT '付款时间', +`delivery_time` datetime NULL COMMENT 'å‘è´§æ—¶é—´', +`receiver_time` datetime NULL COMMENT 'æ”¶è´§æ—¶é—´', +`closing_time` datetime NULL COMMENT 'æˆäº¤æ—¶é—´', +`create_time` datetime NULL COMMENT '创建时间', +`update_time` datetime NULL COMMENT 'æ›´æ–°æ—¶é—´', +`delete` smallint(2) NULL COMMENT 'åˆ é™¤çŠ¶æ€', +`order_type` int(2) NULL COMMENT '订å•类型 0ã€ä¸º Order è®¢å• 1ã€ä¸º OrderItem 订å•', +`status` int(2) NULL COMMENT 'çŠ¶æ€ ç”³è¯·æ¢è´§ã€ç”³è¯·æˆåŠŸã€ç”³è¯·å¤±è´¥ã€æ¢è´§ä¸ã€æ¢è´§æˆåŠŸ', +PRIMARY KEY (`id`) +); + + +CREATE TABLE `order_return` ( +`id` int NOT NULL AUTO_INCREMENT COMMENT 'id自增长', +`order_id` int NOT NULL COMMENT '订å•ç¼–å·', +`order_no` varchar(50) NOT NULL COMMENT '订å•å·', +`sku_id` int NOT NULL COMMENT '商å“ç¼–å·', +`order_item_id` int(11) NOT NULL COMMENT '订å•item id', +`order_logistics_id` int(11) NOT NULL COMMENT 'ç‰©æµ id', + +`order_reason_id` int(11) NULL COMMENT 'é€€è´§åŽŸå› ', +`reason` varchar(255) NULL COMMENT 'æ¢è´§åŽŸå› (其他的时候)', +`create_time` datetime NULL COMMENT '创建时间', +`approval_time` datetime NULL COMMENT 'åŒæ„æ—¶é—´', +`logistics_time` datetime NULL COMMENT 'ç‰©æµæ—¶é—´ï¼ˆå¡«å†™ç‰©æµå•å·æ—¶é—´ï¼‰', +`receiver_time` datetime NULL COMMENT 'æ”¶è´§æ—¶é—´', +`closing_time` datetime NULL COMMENT 'æˆäº¤æ—¶é—´', +`order_type` int(2) NULL COMMENT '订å•类型 0ã€ä¸º Order è®¢å• 1ã€ä¸º OrderItem 订å•', + +`update_time` datetime NULL COMMENT 'æ›´æ–°æ—¶é—´', +`delete` smallint(2) NULL COMMENT 'åˆ é™¤çŠ¶æ€', +`status` int(2) NULL COMMENT 'çŠ¶æ€ ç”³è¯·æ¢è´§ã€ç”³è¯·æˆåŠŸã€ç”³è¯·å¤±è´¥ã€é€€è´§ä¸ã€é€€è´§æˆåŠŸ', +PRIMARY KEY (`id`) +); + + +CREATE TABLE `order_logistics` ( +`id` int NOT NULL AUTO_INCREMENT COMMENT 'id自增长', +`area_no` int NOT NULL COMMENT '订å•ç¼–å·', +`name` VARCHAR(20) NOT NULL COMMENT 'åç§°', +`mobile` VARCHAR(20) NOT NULL COMMENT '手机å·', +`address` VARCHAR(255) NOT NULL COMMENT '详细地å€', +`logistics_no` VARCHAR(20) NOT NULL COMMENT '物æµå•å·', +PRIMARY KEY (`id`) +); + + +CREATE TABLE `order_logistics_detail` ( +`id` int NOT NULL AUTO_INCREMENT COMMENT 'id自增长', +`order_logistics_id` int NOT NULL COMMENT '物æµç¼–å·', +`logistics_time` datetime NOT NULL COMMENT 'ç‰©æµæ—¶é—´', +`logistics_information` VARCHAR(20) NOT NULL COMMENT '物æµä¿¡æ¯', +PRIMARY KEY (`id`) +); + + + + + + + + + + + + + -- 2.17.1