【java开发数据库篇】之mysql乐观锁、悲观锁、共享锁、排它锁、行锁、表锁

900 阅读2分钟

前言: mysql乐观锁、悲观锁、共享锁、排它锁、行锁、表锁概念,此文章仅代表鄙人的总结和理解,如有错漏,欢迎指正...

乐观锁

乐观锁不是数据库自带的,需要我们自己去实现。
通常实现是这样的:在表中的数据进行操作时(更新),先给数据表加一个版本(version)字段,每操作一次,将那条记录的版本号加1。

悲观锁(共享锁和排它锁是悲观锁的不同的实现)

每次操作时都要通过获取锁才能进行对相同数据的操作,这点跟java中的synchronized很相似,所以悲观锁需要耗费较多的时间。另外与乐观锁相对应的,悲观锁是由数据库自己实现了的,要用的时候,我们直接调用数据库的相关语句就可以了。

共享锁

共享锁指的就是对于多个不同的事务,对同一个资源共享同一个锁。相当于对于同一把门,它拥有多个钥匙一样。在执行语句后面加上lock in share mode就代表对某些资源加上共享锁了。

SELECT * from city where id = "1"  lock in share mode;
//加了共享锁之后,对于update,insert,delete语句会自动加排它锁,所以即使在其他sql语句上加上lock in share mode也会报错的

排它锁

排它锁与共享锁相对应,就是指对于多个不同的事务,对同一个资源只能有一把锁。 与共享锁类型,在需要执行的语句后面加上for update就可以了

行锁

行锁,由字面意思理解,就是给某一行加上锁,也就是一条记录加上锁。 比如之前演示的共享锁语句

begin;
SELECT * from city where id = "1"  lock in share mode;
COMMIT;

由于对于city表中,id字段为主键,就也相当于索引。执行加锁时,会将id这个索引为1的记录加上锁,那么这个锁就是行锁。

表锁

表锁,和行锁相对应,给这个表加上锁。 MyISAM引擎里有的

总结:

InnoDB的行锁是针对索引加的锁,不是针对记录加的锁。并且该索引不能失效,否则都会从行锁升级为表锁。


结语:以往都是看别人的博客进行学习技术,其中不乏有精华博客也有吊儿郎当的CV大法文章,所以决定将自己所学所用所整理的知识分享给大家,主要还是想为了后浪们少走些弯路,多些正能量的博客,如有错漏,欢迎指正,仅希望大家能在我的博客中学到知识,解决到问题,那么就足够了。谢谢大家!(转载请注明原文出处)