django使用mysql事务处理_Django中MySQL事务的使用

Django中事物的使用

from django.db import transaction

@transaction.atomic

通过transaction的@transaction.atomic装饰器来开启事务,在视图逻辑涉及数据库操作的地方添加事物保存点,在操作不满足时进行事物回滚,在操作满足是进行事物提交

# 前端传递的参数:地址id(addr_id) 支付方式(pay_method) 用户要购买的商品id字符串(sku_ids)

# mysql事务: 一组sql操作,要么都成功,要么都失败

# 高并发:秒杀

# 支付宝支付

class OrderCommitView(View):

'''订单创建'''

@transaction.atomic

def post(self, request):

'''订单创建'''

# 判断用户是否登录

user = request.user

if not user.is_authenticated():

# 用户未登录

return JsonResponse({'res': 0, 'errmsg': '用户未登录'})

# 接收参数

addr_id = request.POST.get('addr_id')

pay_method = request.POST.get('pay_method')

sku_ids = request.POST.get('sku_ids')

# 校验参数

if not all([addr_id, pay_method, sku_ids]):

return JsonResponse({'res': 1, 'errmsg': '参数不完整'})

# 校验支付方式

if pay_method not in OrderInfo.PAY_METHODS.keys():

return JsonResponse({'res': 2, 'errmsg': '不支持的支付方式'})

# 校验地址

try:

addr = Address.objects.get(id=addr_id)

except Address.DoesNotExist:

# 地址不存在

return JsonResponse({'res': 3, 'errmsg': '地址非法'})

# todo:创建订单核心业务

#组织参数

#订单id:20190416222615+用户id

order_id = datetime.now().strftime('%Y%m%d%H%M%S')+str(user.id)

# 运费

transit_price = 10

# 总数目和总金额

total_count = 0

total_price = 0

# 设置事务保存点

save_id = transaction.savepoint()

try:

# todo: 向df_order_info表中添加一条记录

order = OrderInfo.objects.create(order_id=order_id,

user=user,

addr=addr,

pay_method=pay_method,

total_count=total_count,

total_price=total_price,

transit_price=transit_price)

# todo: 用户的订单中有几个商品,需要向df_order_goods表中加入几条记录

conn = get_redis_connection('default')

cart_key = 'cart_%d' % user.id

sku_ids = sku_ids.split(',')

for sku_id in sku_ids:

# 获取商品的信息

try:

sku = GoodsSKU.objects.get(id=sku_id)

except:

# 商品不存在,进行事物回滚

transaction.savepoint_rollback(save_id)

return JsonResponse({'res': 4, 'errmsg': '商品不存在'})

# 从redis中获取用户所要购买的商品数量

count = conn.hget(cart_key, sku_id)

# todo: 判断商品的库存

if int(count) > sku.stock:

# 库存不足,进行事物回滚

transaction.savepoint_rollback(save_id)

return JsonResponse({'res': 6, 'errmsg': '商品库存不足'})

# todo: 向df_order_goods表中添加一条记录

OrderGoods.objects.create(order=order,

sku=sku,

count=count,

price=sku.price)

# todo: 更新商品的库存和销量

sku.stock -= int(count)

sku.sales += int(count)

sku.save()

# todo: 累加计算订单商品的总数量和总价格

amount = sku.price*int(count)

total_count += int(count)

total_price += amount

# todo: 更新订单信息表中的商品的总数量和总价格

order.total_count = total_count

order.total_price = total_price

order.save()

except Exception as e:

transaction.savepoint_rollback(save_id)

return JsonResponse({'res': 7, 'errmsg': '下单失败'})

# 提交事务

transaction.savepoint_commit(save_id)

# todo: 清除用户购物车中对应的记录

conn.hdel(cart_key, *sku_ids)

# 返回应答

return JsonResponse({'res': 5, 'message': '创建成功'})

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/551414.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python学习笔记全过程_Python学习过程笔记整理(一)

编码方式-Utf8编码方式:# -*- coding: utf-8 -*-注释-行注释 #-块注释 ...或"""..."""基础语法-print()输出默认换行,不换行需要末尾加end""1 print("A",end"")2 print("B")-inp…

http安全 Java_HTTP通信安全-身份验证 | 字痕随行

无论是使用Web Service、RESTful或者其它的基于Http协议的交互方案,不可避免的都需要解决通信方面的安全问题,常见的无非就是:1. 明文传输密码。2. 重放攻击(相关概念参见《HTTP安全-重放攻击》)。3. 请求来源非法。本文通过SHA1算法加/解密相…

python爬取行业数据_用Python进行Web爬取数据

介绍我们拥有的数据太少,无法建立机器学习模型。我们需要更多数据!如果这句话听起来很熟悉,那么你并不孤单!希望获得更多数据来训练我们的机器学习模型是一个一直困扰人们的问题。我们无法在数据科学项目中获得可以直接使用的Exce…

gradle compile mysql_Gradle配置implementation、api与compile的区别

自Gradle 3.4开始,compile被废弃,取而代之的是implementation和api两个配置项。掌握这三者的区别实际上就是要清楚什么情况使用implementation替换compile,什么情况下使用api替换compile。implementation替换compile使用implementation配置依…

python偶数列表_使用条件偶数列表创建带有地图的元组 - python

这是我的代码:evenorodd[1,2,3]list1[a,b,c]list2[A,B,C]res tuple(map(lambda x: True if x % 2 ! 0 else False, evenorodd))print(res)输出:(False, True, False, True)我想要这个:如果x%2! 0则为list1的元素(如果evenorodd的元素为奇数)list2 else的元素(如果e…

java 获取子线程_Java 主线程获取子线程返回结果

1.自定义package com.jgyang.com;public class MySyncThreadTest {public static void main(String[] args) throws Exception {CustomRunnable cRunnacle new CustomRunnable();Thread thread new Thread(cRunnacle,"子线程");thread.start(); //子线程执行System…

winpythonhadoop_让python在hadoop上跑起来

本文实例讲解的是一般的hadoop入门程序“WordCount”,就是首先写一个map程序用来将输入的字符串分割成单个的单词,然后reduce这些单个的单词,相同的单词就对其进行计数,不同的单词分别输出,结果输出每一个单词出现的频…

java解析html jsoup_2020-06-02 jsoup java解析html

AJsoupAJsoup 模块是快速将html 转换成bean 类似gson转换使用前提你了解jsoup并且了解jsoup的SelectGradlecompile com.github.zdongcoding:ajsoup:0.1.0Mavencom.github.zdongcodingajsoup0.1.0pom使用方法如下:bean.javaSelect(select "body")public c…

串口工具securecrt_SecureCRT配置华为交换机部分命令

点上方蓝字“工控先生”免费快速关注本文由“135编辑由于工作需要,昨天临时需要从华为的光电交换机上面的console口查看一些端口的状态等,现整理如下,有需要的可以参考一下:硬件准备串口线,华为交换机连接将RJ45连接到…

java byte 二维数组_[编程入门]二维数组的转置-题解(Java代码)

解题思路:注意事项:参考代码:import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner new Scanner(System.in);int[][] a new int[3][3];for(byte i 0; i for(byte j 0;j a[i][j] scanner.nextInt();}}for(byte i 1; i i…

如何让nginx执行python代码_生产环境部署Python语言代码(django+uwsgi+nginx)

本文主要向大家介绍了生产环境部署Python语言代码(djangouwsginginx),通过具体的内容向大家展示,希望对大家学习Python语言有所帮助。基础环境不做介绍,在django开发web项目完成后,一直使用django自带的服务器进行调试&#xff1a…

天天向上续python3.3_Linux 配置系列 四 python3

一、环境准备JDK版本: jdk1.8; 操作系统: centos 7.6 ;Python::3.7.7; tomcat: apache-tomcat-8.5.5;二、配置python32.1 python3依赖包yum install gcc patch libffi-devel python-…

micropython用什么编译_micropython开发者指南

Authorshaniadolphin获取git工程mkdir micropythoncd micropythongit clone https://github.com/micropython/micropython.gitgit submodule update --init运行的结果如下:dolphinDESKTOP-DR5OKOG:/mnt/h/proj/micropython$ cd micropython/dolphinDESKTOP-DR5OKOG:…

java 跳转虚拟目录_java tomcat虚拟目录的深入了解

我们知道,Web网站中的内容(包括网页,图片,音频文件等)一般都存放在App的目录下。但随着网站内容的不断丰富,用户需要把不同层次的内容组织成网站的子目录。我们通常的做法是在网站主目录下新建子目录,并把相关的内容放…

redis工具类_SpringBoot 操作 Redis 数据

SpringBoot 操作 Redis 数据简介 Redis 是一个开源的NoSQL数据库,基于内存的键值存储,速度快。Redis 支持数据结构,如字符串,散列,列表,集和带范围查询的有序集。5种主要数据类型:字符串类型 …

java判断日期是否是同一周_JAVA里面怎样判断一个日期是否是星期六或者星期天,给出原代码,多谢!!!!!!!!!!...

分数全部奉上。|void test2(){String tmp "2001-09-02";SimpleDateFormat sdf new SimpleDateFormat("yyyy-MM-dd");try {Date myDate sdf.parse(tmp);Calendar myCalendar Calendar.getInstance();myCalendar.setTime(myDate);int i myCalendar.get(…

python中继承是什么意思_Python面向对象中的继承是什么意思

Python面向对象中的继承是什么意思发布时间:2020-11-09 14:05:42

python ansible模块_ansible常用模块

一、ansible常用模块模块是Ansible执行的最小单位,可以是由Python编写,也可以是Shell编写,也可以是由其他语言编写。一、ping模块测试连接可通性,没有参数。通的话返回pong。1、使用示例ansible all -m ping1、可通,返…

java断点续传 框架_java实现断点续传

用java的URL实现了一个简单的断点续传的列子,不为别的,假如你对断点续传不了解一看就明白了呵呵,算不上高深啊package test;import java.io.FileNotFoundException;import java.io.IOException;import java.io.InputStream;import java.io.Ra…

python大文件排序_Python实现大文件排序的方法

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里云文件存储NAS是一个可共享访问&#xf…