锁机制

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

共享锁:代号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使用行锁

posted on 2017-08-26 17:19  zawjdbb  阅读(102)  评论(0编辑  收藏  举报

导航