当执行事务时,相当于执行了锁,来保持数据的一致性,但是锁分多种,有行锁,表锁。行锁就是只锁定那一行,那一条记录,别的连接下的操作还可以操作这张表。表锁就是锁定整张表,只有当前连接执行完事务,才可以解锁。
就效率而然,当然是行锁好,适用与多线程和高并发的情况,不过行锁对数据库会带来额外的开销。表锁高并发就差一点了,但单个的话快一点。
以mysql为例,有索引并且使用了该索引当条件的时候就是行锁,没有索引的时候就是表锁。innodb
锁是对于别的连接来说,不是对于当前连接,即当前连可以一直不加rollback,commit,一路更新,但是别的连接就不行,必须等加了锁的连接释放(rollback,commit)后才能更新,插入
建议:对于插入操作,一般加表锁,但是对于修改和删除操作,最好加行锁,这样在高并发时,不用等太久
加锁方式:
select
update
更新操作,插入,删除操作,在事务中均属于加锁
Oracle行级锁、表级锁
一、行级锁:
(下面这句将给该表的所有行都加上锁)
select * from person for update;
如果该行记录已经被锁定,就不用等待,系统会直接抛错 ora-00054
select * from person where id = '1' for update nowait
如果该行记录已经被锁定,更新的时候等待5秒,如果这5秒内,该行记录被解锁,那么返回查询结果,如果5秒内仍未解锁,那么系统会直接抛错 ora-00054
select * from person for update wait 5;
另外,如果使用 select * from person where id = '1' for update ,当该行记录已经被锁定时,那么系统将一直等待该行记录被释放后,再加锁。
二、表级锁:
行共享:允许用户进行任何操作,禁止排他锁
lock table person in row share mode;
行排他:允许用户进行任何操作,禁止共享锁
lock table person in row exclusive mode;
共享锁:其他用户只能看,不能修改
lock table person in share mode;
共享行排他:比共享锁有更多限制
lock table person in share row exclusive mode;
排他锁:其他用户只能看,不能修改,不能加其他锁
lock table person in exclusive mode;
对于通过lock table命令主动添加的锁定来说,如果要释放它们,只需要发出rollback命令即可。