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