Hello! 欢迎来到小浪云!


MySQL UPDATE语句中使用多个字段作为筛选条件,是锁表还是锁行?


avatar
小浪云 2024-11-09 73

MySQL UPDATE语句中使用多个字段作为筛选条件,是锁表还是锁行?

where子句同时使用多个字段锁表还是锁行

mysql中使用UPDATE语句时,where子句中使用了两个字段(id和is_delete),锁表还是锁行引发了疑问。

锁表与锁行

锁表会锁定整个表,阻止其他事务对此表的任何操作。而锁行则只锁定被更新的行,允许其他事务访问表中的其他行。

MySQL的锁机制

不同的MySQL版本和引擎使用不同的锁机制。在MySQL 5.7及更高版本中,默认情况下使用多版本并发控制(MVCC),该机制使用读写锁来实现并发和隔离性。

针对本例的分析

在给定的UPDATE语句中,where子句中的两个字段 (id和is_delete) 都用作筛选条件。这意味着,MySQL将根据这两个条件筛选出符合条件的行,并且只锁住这些行(锁行)。这样可以避免锁定整个表,提高并发性。

因此,在给定的情况下,UPDATE语句将只锁住符合id = 1且is_delete = 0条件的行,而不会锁住整个表。

相关阅读