码迷,mamicode.com
首页 > 其他好文 > 详细

锁机制

时间:2017-08-26 18:43:31      阅读:143      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!