关于python:Django电商网站订单设计

5次阅读

共计 812 个字符,预计需要花费 3 分钟才能阅读完成。

1、订单页面总共分为 3 个局部
一、订单筹备页面:
新建两个数据库表,一个是订单表 一个是订单商品表,一对多的关系,不便对订单数据进行存储和治理,
须要依据用户信息(request.user)从后盾获取用户的地址信息(未删除的),展现到前端;而后须要获取用户的购物车信息(已勾选的商品和件数),也就是上文中构建的 new_cart_dict = {},依据 sku 获取商品价格,而后乘以商品总价加上运费即可获取订单总金额;此外须要用户选中收货地址和领取形式响应给下一个页面,即订单展现页面;

二、订单展现页面:
2.1 接管前端传来的两个数据,即收货地址和领取形式,获取用户信息。
2.2 生成订单 id(日期 + 工夫 + 用户 id);
2.3 初始化订单数量 0 订单金额 0;
2.4 组织订单状态(如果是货到付款,则订单状态为待发货,如果是支付宝,则显示为待付款);
2.5. 订单商品信息 (咱们从 redis 中获取选中的商品信息)

        2.5.1 连贯 redis
        2.5.2 获取 hash
        2.5.3 获取 set
        2.5.4 类型转换, 转换过程中从新组织数据
            选中的数据
            {sku_id:count,sku_id:count}
        2.5.5 获取选中的商品 id  [1,2,3]
        2.5.6 遍历 id
        2.5.7 查问 count
        2.5.8 判断库存是否少于订单,如果没少则持续,如果少了则反馈库存有余
        2.5.9 缩小 MySQL 中该 sku 的库存值, 减少 spu 和 sku 的销量值
        2.5.10 保留商品信息,示例如下:OrderGoods.objects.create(
                order=order,
                sku=sku,
                count=count,
                price=sku.price
            )
        2.5.11 累加计算 总金额和总数量
    2.6. 保留订单信息的批改

三、订单胜利页面:
响应信息如下:
context = {

        'order_id': order_id,
        'payment_amount': payment_amount,
        'pay_method': pay_method
    }
正文完
 0