4 幻影 user1 run begin tran select tab1 where ... ... select tab1 where commit 虽然将user1的会话环境中设置事务隔离级别为repeatable read,但当user1在交易中执行两次select,所得到的结果还会不一样,这便是幻影。因为user1仅仅将select出来的行加了S锁,但user2可以insert满足where条件的新行,使得两次select的结果不一样,解决方法是将user1的会话环境中设置事务隔离级别为serializable,或者在表级锁定选项中选holdlock
锁定超时: 前面说过,当某个语句因为锁而不能立即执行时,会等待,直到锁被释放。但如果持有锁的语句执行时间过长(未优化)。那么就会等待过长,影响响应,因此,我们通过lock_timeout来将等待过长的语句rollback。需要注意的是,当数据量增加时,可能发生不希望的lock_timeout。原因是SQL需要更多的时间来处理数据,为此我们也需要适当的增加lock_timeout。 索引在锁中的应用。 大家都知道索引可以提高查询速度,其实索引还有一个很重要的功能就是提高并发。 例。当user1 run update tab1 set col1=xxx时,user2对tab1 run select * from tab1将会等待,直到user1执行完。但如果user2执行select * from tab1 where col1<>xxx也就是user2要查询的行并不是user1改写的行,结果如何呢?同样,user2也要等到user1执行完.这样就没有什么并发可言。如果我们在col1上建立index,就可以让user2无须等待,立即执行。更常用的是父表和子表的情况,通常为了保证引用完整性,SQL在修改数据时,都会将依赖表加锁,但如果有index,情况就好的多。