django中实现悲观锁与乐观锁
1.数据库并发处理问题
在多个用户同时发起对同一个数据提交修改操作时(先查询,再修改),会出现资源竞争的问题,导致最终修改的数据结果出现异常。
比如限量商品在热销时,当多个用户同时请求购买商品时,最终修改的数据就会出现异常
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RWpbej13-1636196467076)(2018082423563121)]
实例一:
数据库模型:
from django.db import models
class GoodsInfo(models.Model):
""" 商品 """
name = models.CharField(max_length=50, verbose_name='名称')
stock = models.IntegerField(default=0, verbose_name='库存')
class Meta:
db_table = 'tb_goodsinfo'
视图:
from django.http import HttpResponse
from rest_framework.generics import GenericAPIView
from app01.models import GoodsInfo
class Goods(GenericAPIView):
""" 购买商品 """
def post(self, request):
# 获取请求头中查询字符串数据
goods_id = request.GET.get('goods_id')
count = int(request.GET.get(