读锁和写锁的定义
读锁:又称共享锁,S锁。对于同一条记录,一个事务加读锁时,另一个事务也能加读锁,但是不能加写锁。
写锁:又称独占锁,X锁。对于同一条记录,一个事务加写锁时,另一个事务不能加读锁,也不能加写锁。
InnoDB存储引擎默认使用锁级别
默认使用行锁,支持表级锁。即默认锁一行或者多行记录,但是某些场景行锁会升级为表锁,锁定全部记录。
默认情况下,mysql不会自动加读锁,会自动加写锁。
不加锁,即使存在行锁甚至表锁的情况下也能查询,因为不需要获取锁。
select * from order where id=5
指定加锁,lock in share mode,如果记录存在写锁,则下面sql会阻塞。
select * from order where id = 5 lock in share mode
自动加写锁
update order set pay_status='1' where id=5
自动加写锁
delete from order where id=5
行锁升级为表锁场景
场景一,查询全部数据或者删除全部数据
select * from order for update;(加的写锁)
delete from order;
场景二,未使用索引或者索引失效
update order set pay_status='5' where trx_id='20230331'; (trx_id未加索引,数据量大时耗时长,如果锁表的话会严重影响业务)
参考: