订单前后台分离.md 7.1 KB

确认订单

MQ消息数据结构

exchanges amq.topic
route key order.orderStatus
{"orderCode":100000,"status":700}

取消订单

MQ消息数据结构

exchanges amq.topic
route key order.orderStatus
{"orderCode":100000,"status":900}

订单状态同步

MQ消息数据结构

exchanges amq.topic
route key order.erpstatus
{"orderCode":100000,"status":901}

前台创建换货单

MQ消息数据结构

exchanges amq.topic
route key order.createChangeOrder
{
    "id": 1,
    "city": "南京市",
    "area_code": "320115",
    "address": "江宁经济技术开发区苏源大道87号(有货物流中心订单组)",
    "consignee_name": "测试",
    "county": "江宁区",
    "delivery_tpye": 10,
    "email": "",
    "exchange_mode": 10,
    "mobile": "13776693005",
    "order_code": 16062099,
    "init_order_code": 16062099,
    "source_order_code": 16062099,
    "province": "江苏省",
    "receipt_time": "2",
    "remark": "用户换货",
    "uid": 8041518,
    "zip_code": "211100",
    "goods": [
        {
            "exchange_reason": "3",
            "goods_type": "1",
            "last_price": "88.00",
            "new_goods_id": 354687,
            "new_product_skc": 279434,
            "new_product_sku": 892152,
            "product_skc": 279434,
            "product_skn": 51152761,
            "product_sku": 892152,
            "remark": ""
        }
    ]
}

ERP创建换货单

MQ消息数据结构

exchanges amq.topic
route key erp.createChangeOrder

成功

{
    "code": 200, 
    "message": "ok", 
    "data": {
        "id": 1, 
        "init_order_code": "111", 
        "source_order_code": 1111, 
        "new_order_code": 1111, 
        "exchange_id": 111, 
        "returned_id": 111, 
        "exchange_status": 10, 
        "returned_status": 10
    }
}

失败

{
    "code":500,
    "message":"error",
    "data":{ 
        "id": 1, 
        "init_order_code": "111", 
        "source_order_code": 1111, 
        "new_order_code": 1111, 
        "exchange_id": 111, 
        "returned_id": 111, 
        "exchange_status": 91,  // 客服驳回
        "returned_status": 91   // 客服驳回
    }
}

前台更新换货快递信息

MQ消息数据结构

exchanges amq.topic
route key order.updateChangeRefundOrderExpressInfo
{   "id":1,
    "apply_id":40,
    "express_number":"603596395359",
    "express_name":"顺丰",
    "express_id":"23",
    type:"change"       // 表示类型为换货
}

ERP更新换货单状态

MQ消息数据结构

exchanges amq.topic
route key erp.updateChangeRefundOrderStatus
{   
    "returned_id":1,        //returned_id为erp系统退货单id唯一主键
    "status":40,
    "type":"change"     //"change" 表示换货类型,"refund"表示退货类型
}

前台创建退货单

MQ消息数据结构

exchanges amq.topic
route key order.createRefundOrder
{
    "uid": "3342109",
    "alipay_account": "13912008849",
    "alipay_name": "xxxx",
    "area_code": "area_code",
    "bank_card": "6228480605428963215",
    "bank_name": "中国农业银行",
    "city": "南京市",
    "county": "",
    "order_code": "308545172",
    "payee_name": "张璐",
    "province": "江苏省",
    "remark": "尺寸不合适",
    "return_amount_mode": "2",
    "order_returned_id":123,//前台表生成的退货订单主键,其余字段同老接口
    "returned_goods_list": [
        {
            "product_sku": "383669",
            "goods_type": "1",
            "last_price": "334",
            "returned_reason": "1",
            "remark": "尺寸不合适",
            "evidence_images": ""
        }
    ]
}

ERP创建退货单

MQ消息数据结构

exchanges amq.topic
route key erp.createRefundOrder

成功

{
    "code": 200, 
    "message": "ok", 
    "data": {   
        "order_returned_id":1,      //order_returned_id为前台退货id唯一主键
        "returned_id":1,            //returned_id为erp退货id唯一主键
        "returned_status":10,
        "real_returned_amount":100,
        "is_return_coupon":"N",
        "return_yoho_coin":11111
    }
}

失败

{
    "code":500,
    "message":"error",
    "data":{ 
        "order_returned_id":1,      //order_returned_id为前台退货id唯一主键
        "returned_id":1,            //returned_id为erp退货id唯一主键
        "returned_status":91       //客服驳回
    }
}

前台更新退货快递信息

MQ消息数据结构

exchanges amq.topic
route key order.updateChangeRefundOrderExpressInfo
{   "order_returned_id":1,      //order_returned_id为前台退货id唯一主键
    "apply_id":40,              //apply_id为erp退货id唯一主键
    "express_number":"603596395359",
    "express_name":"顺丰",
    "express_id":"23"
    "type":"refund"            // 表示类型为退货
}

ERP更新退货单状态

MQ消息数据结构

exchanges amq.topic
route key erp.updateChangeRefundOrderStatus
{   
    "returned_id":1,        //returned_id为erp系统退货单id唯一主键
    "status":40,
    "type":"refund"        //"change" 表示换货类型,"refund"表示退货类型
}

取消订单

影响数据库

操作方式 表名 主要字段 描述
U yh_orders.orders is_cancel = 'Y', cancel_type = 2 订单状态
U yhb_promotion.coupons_logs status = 0, is_cancel = 'Y',use_time = 0, order_code =0 返优惠券
I yhb_promotion.user_coupon_logs_sync 返优惠券
U yhb_promotion.user_promotion_code_history is_use = 0 返限购码
U yhb_promotion.limit_code_use_record status = 1, update_time 返限购码
I yoho_passport.yoho_redenvelopes type = 3 返红包
I yoho_passport.yoho_coin_cost 返YOHO币
I yoho_passport.yoho_coin_history 返YOHO币

订单状态同步

影响数据库

操作方式 表名 主要字段 描述
U yh_orders.orders status 订单状态

前台创建换货单

影响数据库

操作方式 表名 主要字段 描述
I yh_orders.refund_goods 退换货列表
I yh_orders.refund_goods_list 退换货列表
I yh_orders.change_goods 换货单
I yh_orders.change_goods_list 换货单商品
U 库存表

前台更新换货快递信息

影响数据库

操作方式 表名 主要字段 描述
I/U yh_orders.express_orders 快递信息表
U yh_orders.refund_goods 退换货列表