ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

for update

2021-07-15 09:58:19  阅读:162  来源: 互联网

标签:耗时 update 索引 user balance id


intert update delete本身就是行锁

MySQL FOR UPDATE 锁级别
结论
开启事务后,使用for update 会锁表,按照索引字段查询除外。
开启事务后,按照索引索引字段会锁住该行数据,其他不受影响。
FOR UPDATE 是写锁,读操作不会锁住。
不开启事务,FOR UPDATE 不会锁任何数据。
例子
现有如下记录表,其中user_id添加了索引。

#SELECT user_id,balance FROM tb_user_account for update;
+---------+---------+
| user_id | balance |
+---------+---------+
|      80 |       0 |
|      86 |      45 |
+---------+---------+

无锁
#连接1
SELECT user_id,balance FROM tb_user_account for update;
#连接2 仍然可以查询
SELECT user_id,balance FROM tb_user_account for update;

表锁
1.事务中查询非索引字段会锁表。
#连接1开启事务
START TRANSACTION;
#连接1查询非索引字段
SELECT user_id,balance FROM tb_user_account WHERE balance = 0 forUPDATE;
#连接2按索引字段查询,被锁住。
SELECT user_id,balance FROM tb_user_account WHERE user_id = 86 for update;
#ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

行锁
1.事务中查询索引字段会锁该行数据。
#连接1开启事务
START TRANSACTION;
#连接1查询索引字段 user_id = 86
SELECT user_id,balance FROM tb_user_account WHERE user_id = 86 forUPDATE;
#连接2按索引字段查询 user_id =86,被锁住。
SELECT user_id,balance FROM tb_user_account WHERE user_id = 86 for update;
#ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
#连接2按索引字段查询 user_id =80 ,未被锁住。
SELECT user_id,balance FROM tb_user_account WHERE user_id = 80 for update;
+---------+---------+
| user_id | balance |
+---------+---------+
|      80 |       0 |
+---------+---------+

E450 i5 16g 性能测试
一个用户50条

CAS
耗时:7257 1-11
耗时:7713 11-22
耗时:7408 23-34

悲观锁
耗时:15610 0-50
耗时:15848 50-100


每个用户10条

悲观锁
耗时:6092
耗时:7023
耗时:6300

CAS
耗时:5381
耗时:5555
————————————————
版权声明:本文为CSDN博主「翰林小院」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/proc_871113/article/details/87359932

标签:耗时,update,索引,user,balance,id
来源: https://blog.csdn.net/lengyue1084/article/details/118752589

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有