对于实验数据中的age列,现有的数据为1,5,9,11,那么针对age列将会有1,5,9,11这4个锁,当筛选条件中的column被精准命中时,也就是说sql中写成where age = x时,这是被 *** 作的记录,将会被锁定。举个例子:
开启2个事物session1,session2
直接执行行3,箭头指向的位置一直在转圈,无法对age=5的记录加排它锁。
现有的数据为1,5,9,11,那么对于age列,将会有以下几个开区间
(-∞, 1), (1, 5), (5, 9), (9, 11), (11, +∞)。
直接执行行4,能看到一直在转圈。因为age >6 and age <8落在了(9, 11)这个开区间内,那么(9, 11)这个开区间内的与age列相关的dml语句都会被锁。这里演示的是insert,那么update的?没有update,因为既然有(9, 11)这个开区间,那么就说明(9, 11)的间隙里没有数据。
与间隙锁的区别:查询条件落只在间其中一个开区间内,将会进行锁定。临键锁则是,当查询条件跨越了超过一个开区间,比如:where age >6 and age <10,这个条件落在了(5, 9), (9, 11)这2个区间内,它让存在的记录锁里的age=9也被包含在了符合的条件里。这是就会有如下临键锁了
(-∞, 1], (1, 5], (5, 9], (9, 11], (11, +∞),可以看到临键锁就是记录锁与间隙锁的并集,是一个左开右必的区间。这是,将会对被落到的区间内的符合条件的记录进行锁定,(5, 9], (9, 11]被锁定,也就是(5, 11]这个区间内的记录被锁定了。下面来 *** 作:
mysql用于将事物处理写入sql语句中参考以下内容在 SQL 语言中,实现事务的提交的语言是 COMMIT REVOKE :废除某用户或某组或所有用户的访问权限。
MySQL 事务主要用于处理 *** 作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人员,你既需要删除人员的基本资料,也要删除和该人员相关的信息。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)