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)

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REaDME.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 、资源1项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值