MySQL对于各种锁的概念理解
作者:灰灰是菇凉呀 发布时间:2024-01-17 17:18:36
乐观锁
乐观锁大多是基于数据版本记录机制实现,一般是给数据库表增加一个"version"字段。读取数据时,将此版本号一同读出,之后更新时,对此版本号加一。此时将提交数据的版本数据与数据库表对应记录的当前版本信息进行比对,如果提交的数据版本号大于数据库表当前版本号,则予以更新,否则认为是过期数据。
比如下单操作:
查询出商品信息。
select (quantity, version)
from t_goods
where id = #{id}
根据商品信息生成订单。
将商品数量减1。
update t_goods
set quantity = quantity - 1
where id = #{id} and version = #{version}
悲观锁
悲观锁依靠数据库提供的锁机制实现。MySQL中的共享锁和排它锁都是悲观锁。数据库的增删改操作默认都会加排他锁,而查询不会加任何锁。
共享锁(读锁)
共享锁指的就是对于多个不同的事务,对于一个资源共享同一个锁。对某一资源加共享锁,自身可可读该资源,其他人也可以读该资源(也可以再加共享锁,即共享锁共享多个内存),但无法修改。要想修改就必须等所有共享锁都释放完之后。语法:select * from table lock in share mode;
。
比如:
窗口1,在一个未结束的事务中给一条数据加上共享锁。
BEGIN;
SELECT * FROM t_red_packet WHERE id = 1 LOCK IN SHARE MODE;
窗口2,给同一条数据加上共享锁,加锁成功。
SELECT * FROM t_red_packet WHERE id = 1 LOCK IN SHARE MODE;
窗口1和窗口2,更新该行数据,提示[Err] 1205 - Lock wait timeout exceeded; try restarting transaction
。需要等到所有共享锁释放,才可以进行update操作。
UPDATE t_red_packet
SET user_id = 2
排它锁(写锁)
排它锁指的就是对于多个不同的事务,对同一个资源只能有一把锁。对某一资源加排它锁,自身可以进行增删改查,其他人无法进行加锁操作,更无法进行增删改操作。语法:select * from table for update
。
窗口1,在一个未结束的事务中给一条数据加上排它锁。
BEGIN;
SELECT * FROM t_red_packet WHERE id = 1 FOR UPDATE;
窗口1,更新该行数据,成功。
UPDATE t_red_packet
SET user_id = 2
窗口2,查询该行数据,可以查询到。
SELECT * FROM t_red_packet WHERE id = 1
窗口2给该条数据加锁,提示[Err] 1205 - Lock wait timeout exceeded; try restarting transaction
。
SELECT * FROM t_red_packet WHERE id = 1 FOR UPDATE;
综上,共享锁就是大家一起来读,一起来共享锁,但谁都不要对锁着的数据进行修改,排它锁就是我自己就是想来修改,你们可以读,但你们都不能到锁,也不能对数据进行修改。
行锁
行锁就是给一行数据进行加锁。
表锁
表锁就是对一张表进行加锁。
来源:https://blog.csdn.net/sinat_28394909/article/details/84786362
![](https://www.aspxhome.com/images/zang.png)
![](https://www.aspxhome.com/images/jiucuo.png)
猜你喜欢
- 百度作业帮提问:python if not in 多条件 判断怎么写s = ['1','2'] 判断条件st
- 考点:将字典转换为XML文档;将XML文档转换为字典。面试题1.面试题一:如何将一个字典转换为XML文档,并将该XML文档保存为文本文件。2
- 如下所示:import osos.system()os.popen().read().strip()#上面2种方法 是python 执行终端
- 有这样的情形,django个人头像在model中是:class UserProfile(AbstractUser): ""
- 1. 实例描述在平时编程的过程中,会经常在网上翻译一些单词,本文使用Python制作一款翻译小工具,不仅可以自己用,还可以嵌入到程序当中。运
- 本文实例为大家分享了python实现人民币转大写人民币的具体代码,供大家参考,具体内容如下直接上代码:# -*- coding: utf-8
- 简介ICO是一种图标文件格式,图标文件可以存储单个图案、多尺寸、多色板的图标文件。一个图标实际上是多张不同格式的图片的集合体,并且还包含了一
- Pandas之drop_duplicates:去除重复项方法DataFrame.drop_duplicates(subset=None, k
- Facebook的网站速度做为最关键的公司任务之一。在2009年,我们成功地实现了Facebook网站速度提升两倍 。而正是我们的工程师团队
- 一、汉诺塔问题1. 问题来源问题源于印度的一个古老传说,大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄
- Python算术运算符以下假设变量a为10,变量b为20:运算符描述实例+加 - 两个对象相加a + b 输出结果 30-减 - 得到负数或
- 前言在写程序时,我们会经常碰到程序出现异常,这时候我们就不得不处理这些异常,以保证程序的健壮性。处理异常的版本有以下几种,你通常的做法是哪种
- 前言我们可以给视图函数加装饰器来判断是用户是否登录,把没有登录的用户请求跳转到登录页面等等。我们通过给几个特定视图函数加装饰器实现了这个需求
- ssh limit perl脚本主要作用:1.限制一个ssh用户的最大登录数为n,n可自定义。2.支持白名单,如root、test登录不受限
- 本文实例讲述了python通过smpt发送邮件的方法。分享给大家供大家参考。具体实现方法如下:import smtplib, socketf
- 实例如下:import urllib.requestimport urllib.parseimport jsonwhile True: &n
- 随着当今世界的发展,计算机视觉技术的应用越来越广泛。伴随着硬件设备的不断升级,构造复杂的计算机视觉应用变得越来越容易了。OpenCV像是一个
- 用下列代码可在控制弹出NTLM验证窗口:<% Response.Status = "401 Unauthorized&quo
- 当今互联网时代,数据处理已经成为了一个非常重要的任务。而Redis作为一款高性能的NoSQL数据库,越来越受到了广大开发者的喜爱。本篇博客将
- 方法一使用findspark使用pip安装findspark:pip install findspark在py文件中引入findspark: