mysql锁、事务

innoDB引擎下,update、insert、delete会给涉及到的数据行上排他锁,select默认不加锁。
加排他锁可以使用select … for update语句,加共享锁可以使用select … lock in share mode。

mysql中的锁

可分为两类:
1 共享锁与排他锁(Shared and Exclusive Locks)
都是行级锁,共享锁也称为读锁,多个连接可以同时读取数据,但不能修改,若要修改只能等待所有共享锁释放完。
排他锁,也称为写锁,只通话一个连接持有,其他连接既不能读,也不能写。
2 意向锁(Intension Lock)
意向锁是表级锁,主要是为了解决多级别锁共存的问题(行锁和表锁)。当某个连接在申请行级锁的时候,会先申请表的意向锁,此时若有另外一个连接想要申请表级锁,会发现当前表已有意向锁,会阻塞直到意向锁释放为止。注意,申请意向锁的行为是数据库自身完成的。当事务申请行锁的时候,数据库会先自动申请意向锁。
举例来说:
select … lock in share mode,要获取IS锁;An intention shared lock (IS)
select … for update ,需要先获取IX锁;An intention exclusive lock (IX)
select for update需要结合显式声明事务使用,不则不起作用

注意:mysql行级锁是基于索引的,如果一条sql语句没有用到索引,会用表级锁将表锁住!

InnoDB行锁实现

InnoDB的行锁通过对索引加锁实现,如果没有索引,则对聚簇索引加锁。如果加锁时没有通过索引检索数据,那么相当于InnoDB对全部数据进行扫描加锁,效果等于表锁。

悲观锁

悲观锁,就是预计会发生线程竞争的问题,在一开始读的时候就加上锁,执行完更新操作再去掉。做法是:

begin transaction;
select xx for update;
update table set num = num -1;
commit transaction;

乐观锁
乐观锁可以有两种实现方式
CAS(compare and swap)

发布了24 篇原创文章 · 获赞 0 · 访问量 3368

猜你喜欢

转载自blog.csdn.net/GuXiaoyan12/article/details/103812815