首先排它锁 共享锁 都有一个前提 必须是事务开启状态
都是在事务中发生的。。。。
#共享锁 需要加 lock in share mode
select * from table where .....lock in share mode
#一致性非锁定读
select * from table where ......
#排它锁
update ,insert ,delete 自动的会加上排它锁
select * from table_name where .....for update
举例
共享锁兼容共享锁
图一
图二
图一开启s锁 图二也可以使用共享锁。。。这就代表了s锁 是可以兼容的 共享锁
举例
排它锁 不 兼容共享锁 排它锁
图一 排它锁 x锁
图二 共享锁 s锁 此时因为有图一的x锁 所以s锁 不兼容
图三 排它锁 x锁 也不兼容
结论 s锁和s锁可以相互兼容 x锁和(x锁,s锁)相互不兼容
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/30127122/viewspace-2649854/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/30127122/viewspace-2649854/