数据库锁
为什么要加锁:
加锁的目的是为了解决在多线程访问数据的情况下保证数据的完整性和一致性。
锁的分类:
按粒度划分:表锁、页锁、行锁
按数据库管理划分:共享锁、排它锁
按程序员角度划分:乐观锁、悲观锁
粒度
数据库管理
共享锁,也叫读锁,或者 S 锁,共享锁锁定的资源可以被其他用户读取,但不能修改
在进行 SElECT 的时候,会将对象进行共享锁锁定,当数据读取完毕之后,就会释放共享锁,这样就可以保证数据在读取时不被修改。
排他锁,排他锁也叫做独占锁,写锁或者 X 锁,排他锁锁定的数据只允许进行锁定操作的事务使用,其他事务无法对已锁定的数据进行查询或者修改。
程序员
乐观锁,数据并发并不一定总是发生
悲观锁,依靠数据库自身锁的机制处理数据并发问题