Mysql的悲观锁 你来聊一聊?

摘要:
什么是关系数据库管理系统中的悲观锁定?悲观并发控制是一种并发控制方法。它可以防止事务以影响其他用户的方式修改数据。然后锁定相应的记录。其他事务只能在提交事务后执行。我们使用select Forupdate将锁定数据,但我们需要注意一些锁定级别。MySQL InnoDB默认为行级锁。

什么是悲观锁

在关系数据库管理系统中,悲观并发控制(悲观锁,PCC)是一种并发控制的方法。它可以阻止一个事务以影响其他用户的方式来修改数据。如果一个事务执行的操作的每行数据应用了锁,那只有当这个事务锁释放,其他事务才能够执行与该锁冲突的操作

悲观并发控制主要应用于数据争用激烈的环境,以及发生并发冲突时使用锁保护数据的成本要低于回滚事务的成本环境。

数据库中,悲观锁的流程如下

  • 在对任何记录进行修改之前,先尝试为该记录加上排他锁
  • 如果加锁失败,说明该记录正在被修改,那么当前查询可能要等待或抛出异常
  • 如果成功加锁,则就可以对记录做修改,事务完成后就会解锁
  • 其间如果有其他对该记录做修改或加排他锁的操作,都会等待我们解锁或直接抛出异常

MySQL InnoDB中使用悲观锁

要使用悲观锁,必须关闭mysql数据库的自动提交属性,因为MySQL默认使用autocommit模式,也就是当你执行一个更新操作后,MySQL会立即将结果进行提交

//开始事务
 
begin;/begin work;/start transaction;(三者选一个)
 
select status from t_goods where id=1 for update;
 
//根据商品信息生成订单
 
insert into t_orders (id,goods_id) values (null,1);
 
//修改商品status为2
 
update t_goods set status=2;
 
// 提交事务
 
commit;/commit work;

以上查询语句中,使用了select...for update方式,通过开启排他锁的方式实现了悲观锁。则相应的记录被锁定,其他事务必须等本次事务提交之后才能够执行

我们使用select ... for update会把数据给锁定,不过我们需要注意一些锁的级别,MySQL InnoDB默认行级锁。行级锁都是基于索引的,如果一条SQL用不到索引是不会使用行级锁的,会使用表级锁把整张表锁住

免责声明:文章转载自《Mysql的悲观锁 你来聊一聊?》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇监听器在游戏开发中的应用消息回调使用HttpRunner3+Allure+Jenkins实现Web接口自动化测试下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

二进制日志备份与恢复,快照备份,复制

二进制日志备份与恢复 二进制日志非常关键,我们可以通过它来完成point-in-time的恢复工作。MySQL数据库的复制同样需要二进制日志。默认情况下并不启用二进制日志,要使用二进制日志,首先必须启用它,在配置文件中进行如下设置: [mysqld] log-bin 对于InnoDB存储引擎只是简单启用二进制日志是不够的,还需要启用一些其他参数来保证安全和...

mysql修改表、字段、库的字符集

在一次导入数据表(MYISAM)的经历:复制过来的表打开后中文出现乱码,肯定是字符集出现了不致的问题,所以从原数据库导出.sql文件,修改其中的创建表的语句,加入字符集DEFAULT CHARSET=gb2312 用这个导入 mysql -uroot -p --default-character-set=gb2312 databasename>E:o...

NUMA导致的MySQL服务器SWAP问题分析

【作者】 王栋:携程技术保障中心数据库专家,对数据库疑难问题的排查和数据库自动化智能化运维工具的开发有强烈的兴趣。 【问题描述】 我们知道当mysqld进程使用到SWAP时,就会严重影响到MySQL的性能。SWAP的问题比较复杂,本文会从SWAP的原理开始,分享我们碰到的案例和分析思路。 【SWAP原理】 swap是把一部分磁盘空间或文件,当作内存来使用。...

关于数据并发

当多个用户同时更新同一数据的时候,由于更新可能导致数据的不一致性,使得程序的业务数据发生错误,这种情况可以称之为并发。在ADO .NET中,并发的处理可以通过三种方式来控制:保守式并发控制、开发式并发控制以及最后更新生效方式。 保守式并发控制:数据从数据库取出之后,一直处于锁定的状态,其他用户不能获取该数据,直至数据更新完毕之后,用户才能取出该数据进行...

MySQL5.6绿色版安装(mysql-5.6.24-winx64.zip)

1、数据库安装 Mysql官方网站:http://www.mysql.com/,数据库下载地址:http://www.mysql.com/downloads/。从官方网站可以找到两种文件包,一种是exe安装程序,另一种是zip压缩包。这次我下载的是ZIP压缩包。最新的5.6.24大概350M. 2、数据库安装 解压出下载的文件mysql-5.6.24-wi...

Mysql的union

我同事写了一条Sql语句,当时没看明白,下面晒出来: SELECT SUM(new_cart) as new_cart,SUM(new_collect) as new_collect, SUM(total_cart) as total_cart, SUM(total_collect) as total_collect, SUM(ipv) ipv, SUM(...