首页 > 其他 > 详细

锁机制

时间:2017-08-26 17:49:55      阅读:270      评论:0      收藏:0      [点我收藏+]

解决数据库并发控制问题并实现事务的各个隔离级别

共享锁:代号S锁,锁粒度是行或者元组(多个行),一个事务获取了共享锁后,可以对锁定范围内的数据进行读操作

排他锁:代号X锁,锁粒度与共享锁相同,一个事务获取了共享锁后,可以对锁定范围内的数据进行读和写操作

  事务A获取了一个元组的共享锁,事务B还可以立即获取这个元组的共享锁,但不能立即获取这个元组的排他锁,必须等到事务A释放共享锁之后

  事务A获取了一个元组的排他锁,事务B不能获取这个元组的共享锁和排他锁

意向锁:锁粒度是整张表,分为意向共享锁(IS)和意向排他锁(IX),表示事务有意对数据上共享锁或者排他锁,但还没有真正执行

锁和锁之间要么相容要么互斥

锁a和锁b相容:操作同一组数据时,如果事务A获取了锁a,事务B还可以获取锁b

锁a和锁b互斥:操作同一组时间时,事务A获取了锁a,事务B在事务A释放锁a前不能获取锁b

锁粒度越大,并发越小,系统资源消耗越小,锁粒度主要分为表锁和行锁

表锁管理锁的开销最小,但并发量也最小,MyISAM使用表锁

行锁可以支持最大的并发,InnoDB使用行锁

锁机制

原文:http://www.cnblogs.com/zawjdbb/p/7435883.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!