建议先关注、点赞、收藏后再阅读。
事务的隔离级别有以下四种:
-
读未提交(Read Uncommitted):
- 含义:事务中的修改可以被其他事务立即可见,即一个事务可以读取到另一个事务尚未提交的数据。
- 影响:该隔离级别存在脏读(Dirty Read)问题,即读取到尚未提交的脏数据,可能导致数据的不一致性。
-
读已提交(Read Committed):
- 含义:一个事务只能读取到已经提交的其他事务的数据,即不会出现脏读。
- 影响:该隔离级别避免了脏读问题,但可能会出现不可重复读(Non-repeatable Read)问题,即在同一事务中,相同查询语句可能返回不同的结果。
-
可重复读(Repeatable Read):
- 含义:在同一个事务内的多次读取操作都会返回同样的结果集,即其他事务对数据的修改不会影响已启动的事务。
- 影响:该隔离级别避免了不可重复读问题,但可能会出现幻读(Phantom Read)问题,即在同一事务中,相同的查询条件可能返回不同的行数。
-
串行化(Serializable):
- 含义:所有的事务依次串行执行,每个事务都会在开始执行之前获取一个共享锁,在执行完毕之后释放锁。
- 影响:该隔离级别确保了事务的完全隔离,避免了脏读、不可重复读和幻读问题,但牺牲了并发性能,可能导致数据库性能下降。
数据库锁的类型有以下几种:
-
共享锁(Shared Lock):
也称为读锁,它允许多个事务同时获取相同的共享资源的锁。并发读取是安全的,但写操作被阻塞。适用于读多写少的场景,可以提高并发性能。 -
排他锁(Exclusive Lock):
也称为写锁,它只允许一个事务独占访问资源的锁。其他事务无法获取该资源的共享锁或排他锁。适用于写操作较多、读操作较少的场景,确保数据的一致性。 -
记录锁(Record Lock):
在某些数据库管理系统中,可以对记录级别或行级别进行锁定。在使用记录锁时,只有对表中的特定记录请求锁定。适用于对特定记录进行访问和修改的场景。 -
意向锁(Intent Lock):
意向锁是用来表示一个事务想要在某个对象上获取什么级别的锁,它包括意向共享锁和意向排他锁。意向锁允许并发事务获取共享或排它锁之前,发现是否有其他事务已经持有排它锁或共享锁。 -
表锁(Table Lock):
表锁是一种粗粒度的锁,它锁定整个数据表,其他事务无法对该表进行读写操作。适用于对整个表进行操作的场景,如备份、重建索引等操作。 -
页锁(Page Lock):
页级锁是对页(通常是数据库中连续的若干行)进行锁定,其他事务无法修改该页上的任何行。适用于并发读写较频繁的场景。 -
行锁(Row Lock):
行级锁是对表中的每一行进行锁定,只允许一个事务对该行进行读写操作,可以提供最细粒度的并发控制。适用于高并发读写的场景。
这些锁的应用场景根据不同的需求和并发情况来选择,可以灵活使用以保证数据的安全性和并发性能。