登录
首页 >  数据库 >  MySQL

Django电商网站--订单设计

来源:SegmentFault

时间:2023-01-18 16:30:58 380浏览 收藏

怎么入门数据库编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《Django电商网站--订单设计》,涉及到MySQL、Redis、python、Django,有需要的可以收藏一下

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
    }

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表