MySQL for update 用法解析

基本原理与用法
MySQL在查询语句后面加上 for update ,例如

select * from student where id = 1 for update;

即为手动给读操作加上写锁(或者说给共享锁再加上排它锁)。因为是写锁,如果在此之前有另一个事务对此数据加了写锁,那么当前的查询事务会等待写锁被释放(比如提交或回滚)后再查询。作为解决并发问题的方案之一。

for update nowait:被锁时直接报错而不等待。

for update wait 3:被锁时等待3秒,超过3秒后如果数据还存在写锁,则报错。

一定需要注意的点
for update是根据where的索引情况进行加锁,根据具体情况,可能会产生:行级锁、间隙锁、表级锁。

  • 当查询语句走主键/唯一键索引,且数据全部命中,锁住单行。(即使是范围查询,比如 where id in (1,2,3),如果都存在,也是只锁1,2,3三行)。
  • 当查询语句走主键/唯一键索引,但数据部分命中,或都不命中;或走非唯一索引:用间隙锁,锁住区间行。
  • 当查询语句不走索引,会用间隙锁把整张表锁住(但其实并不是表锁),因此要尽量避免索引失效的场景。

其他补充
间隙锁的范围:
假设数据是这样的

id    name
2    a
6    b
9    c


如果对id=2的数据上间隙锁,则范围是:(-∞,2]、(2,6]

如果对id=6的数据上间隙锁,则范围是:(2,6]、(6,9]

如果对id=9的数据上间隙锁,则范围是:(6,9]、(9,+∞)

另外,开区间的范围是根据主键的排列顺序确定。

锁的介绍:
MyISAM是表级锁,InnoDB默认行级锁,也支持表级锁。

间隙锁只有在InnoDB的RR-可重复读、Serializable级别时才默认支持。

索引失效的常见场景:
联合索引时违背最左匹配原则
范围查询的范围过大,比如>=等范围条件的实际匹配量大、in后面行数较多。
各种语法待试验....面经里写的那些感觉有的不太对,如:

  • 有or必全有索引;
  • 复合索引未用左列字段;
  • like以%开头;
  • 需要类型转换;
  • where中索引列有运算;
  • where中索引列使用了函数;
  • 如果mysql觉得全表扫描更快时(数据少);
  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQLupdate语句是用来修改表格中已有的记录。其基本语法如下: ``` UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE condition; ``` 其中,`table_name`为表格名,`column1`、`column2`等是需要修改的列名,`value1`、`value2`等是相应列名要被修改成的值。`WHERE`子句为可选项,但它的作用是筛选需要被修改的数据,因此通常需要使用。 例如,当我们需要在表格`students`中将`score`列中大于80的分数修改为100时,可以使用以下update语句: ``` UPDATE students SET score = 100 WHERE score > 80; ``` 此外,在update语句中我们还可以使用一些其他的关键字进行特殊操作。以下是几个常用的关键字: - `LIMIT`:用于限制改动的记录数。例如,`UPDATE students SET score = 100 WHERE score > 80 LIMIT 3;`表示只修改满足条件的前3条记录。 - `ORDER BY`:用于对筛选出的数据进行排序。例如,`UPDATE students SET score = 100 WHERE score > 80 ORDER BY score DESC;`表示按分数从高到低排序后,将符合条件的记录的分数修改为100。 - `JOIN`:用于在一个update语句中同时操作多张表格。例如,`UPDATE students AS s JOIN courses ON s.id = courses.id SET s.score = 90 WHERE courses.name = 'Math';`表示修改选了数学课的学生的分数为90。此处`s`为`students`表格的别名。 在使用update语句时需要小心操作,确保修改的数据与条件无误。同时,由于update语句将直接修改表格中的记录,因此也需要充分备份原有数据以防操作失误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值