SELECT * FROM table_name WHERE id = 1 FOR UPDATE;
,用于锁定指定行,防止其他事务修改。 MySQL行锁语句是指在执行SQL操作时,对某一行或多行数据进行锁定,以确保数据的一致性和完整性,在MySQL中,可以使用以下几种行锁语句:
1、使用SELECT ... FOR UPDATE
语句对查询结果进行加锁
当执行SELECT ... FOR UPDATE
语句时,会对查询到的记录加上排他锁(X锁),其他事务无法对这些记录进行修改、删除等操作。
示例:
对id为1的记录加锁 SELECT * FROM table_name WHERE id = 1 FOR UPDATE;
2、使用LOCK IN SHARE MODE
语句对查询结果进行加锁
当执行SELECT ... LOCK IN SHARE MODE
语句时,会对查询到的记录加上共享锁(S锁),其他事务可以对这些记录进行读操作,但无法进行修改、删除等操作。
示例:
对id为1的记录加共享锁 SELECT * FROM table_name WHERE id = 1 LOCK IN SHARE MODE;
3、使用START TRANSACTION
和COMMIT
语句对整个事务进行加锁和解锁
在执行SQL操作前,可以使用START TRANSACTION
语句开启一个事务,然后在事务内对数据进行操作,操作完成后,使用COMMIT
语句提交事务,释放锁。
示例:
开启事务 START TRANSACTION; 对id为1的记录加排他锁 SELECT * FROM table_name WHERE id = 1 FOR UPDATE; 对id为2的记录加排他锁 SELECT * FROM table_name WHERE id = 2 FOR UPDATE; 提交事务,释放锁 COMMIT;
4、使用SET TRANSACTION ISOLATION LEVEL
语句设置事务隔离级别
可以通过设置事务隔离级别来控制MySQL的行锁行为,不同的隔离级别对应不同的锁行为,设置隔离级别为READ COMMITTED
时,MySQL会自动使用行锁。
示例:
设置事务隔离级别为READ COMMITTED SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。