美文网首页
Django开发教程(六)

Django开发教程(六)

作者: 小陈工 | 来源:发表于2022-05-27 07:14 被阅读0次

    十九、提交订单页面显示功能

    19.1在templates/cart.html文件中设置表单提交:

    19.2在order/urls.py中配置对应的url:

    19.3在order/view.py中编写OrderPlaceView类显示订单页面:

    19.4在templates/place_order.html文件中完成订单页面的显示:

    19.5在templates/order_place.html文件中完成创建订单功能:

    19.6在order/urls.py文件中定义提交订单的url:

    19.7数据库MySQL的事务:

    19.7.1事务概念: 一组mysql语句,要么执行,要么全不不执行。

    19.7.2事务特点:

                            1、原子性:一组事务,要么成功;要么撤回。

                            2、稳定性 :有非法数据(外键约束之类),事务撤回。

                            3、隔离性:事务独立运行。一个事务处理后的结果,影响了其他事务,那么其他事务会撤回。事务的100%隔离,需要牺牲速度。

                            4、可靠性:软、硬件崩溃后,InnoDB数据表驱动会利用日志文件重构修改。可靠性和高速度不可兼得,                                               innodb_flush_log_at_trx_commit 选项 决定什么时候吧事务保存到日志里。

    19.7.3事务控制语句:

                                    COMMIT;COMMIT会提交事务,并使已对数据库进行的所有修改称为永久性的;

                                    ROLLBACK;回滚会结束用户的务,并撤销正在进行的所有未提交的修改;

                                    SAVEPOINT identifier;SAVEPOINT允许在事务中创建一个保存点,一个事务中可以有多个SAVEPOINT;

                                    RELEASE SAVEPOINT identifier;删除一个事务的保存点,当没有指定的保存点时,执行该语句会 抛出一个异常;

                                    ROLLBACK TO identifier;把事务回滚到标记点;

    19.7.4事务隔离级别:

                                    Read Uncommitted(读取未提交内容):在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。本隔离级别很少用于实际应用,因为它的性能也不比其他级别好多少。读取未提交的数据,也被称之为脏读(Dirty Read)。

                                    Read Committed(读取提交内容):这是大多数数据库系统的默认隔离级别(但不是MySQL默认的)。它满足了隔离的简单定义:一个事务只能看见已经提交事务所做的改变。这种隔离级别 也支持所谓的不可重复读(Nonrepeatable  Read),因为同一事务的其他实例在该实例处理其间可能会有新的commit,所以同一select可能返回不同结果。

                                    Repeatable Read(可重读):这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。不过理论上,这会导致另一个棘手的问题:幻读 (Phantom Read)。

                                    Serializable(可串行化):这是最高的隔离级别,它通过强制事务排序,使之不可能相互冲突,从而解决幻读问题。简言之,它是在每个读的数据行上加上共享锁。在这个级别,可能导致大量的超时现象和锁竞争。

    19.8提交订单功能的业务分析:

    19.9订单并发处理:

    悲观锁:获取数据时对数据行了锁定,其他事务要想获取锁,必须等原事务结束。

                                使用示例:select * from df_goods_sku where id=17 for update;

    乐观锁:查询时不锁数据,提交更改时进行判断.

                                使用示例:update df_goods_sku set stock=0, sales=1 where id=17 and stock=1;

    19.9.1项目使用原则:

                                冲突比较少的时候,使用乐观锁。

                                冲突比较多的时候,使用悲观锁。

    19.10在order/views.py中定义OrderCommitView订单创建类:

    二十、用户中心的订单页面显示

    20.1在user/urls.py中定义用户中心订单页的url:

    20.2在user/view.py中定义UserOrderView类:

    20.3在templates/user_center_order.html中显示数据:

    相关文章

      网友评论

          本文标题:Django开发教程(六)

          本文链接:https://www.haomeiwen.com/subject/gyhmprtx.html