django中实现悲观锁与乐观锁

本文探讨了在Django中处理数据库并发问题,通过实例分析了并发购买商品导致的库存异常,并提出了两种解决方案:乐观锁,通过版本记录机制确保数据一致性;以及悲观锁,利用数据库锁机制确保数据的独占访问。总结了乐观锁和悲观锁的适用场景和优缺点。
摘要由CSDN通过智能技术生成

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(
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值