数据库事务与锁

开启事务就自动加锁。
事务与锁是不同的。事务具有ACID(原子性、一致性、隔离性和持久性),锁是用于解决隔离性的一种机制。
事务的隔离级别通过锁的机制来实现。另外锁有不同的粒度,同时事务也是有不同的隔离级别的。
一个事务执行的任何过程中都可以获得锁,但是只有事务提交或回滚的时候才释放这些锁。

锁分类:
共享锁(读锁、S锁):加上共享锁后,其他用户不能获取排它锁,也就是说只能读不能写。例:事务里面做查询的查询操作就是加共享锁。
排它锁(写锁、X锁):加上排它锁后,其他用户不能获取任何锁,只有自己可以读、写。例:事务里做insert、update、delete就是加排它锁。
共享锁、排它锁属于悲观锁。
乐观锁:乐观锁的操作过程中没有任何锁的参与,乐观锁只是和悲观锁相对,严格的说乐观锁不能称之为锁,因为没有锁参与。

事务隔离级别(从上往下级别越严格):
1、ReadUncommitted(Read-Uncommitted即读取未提交):事务A修改数据,但是事务未提交;事务B中查到事务A中修改的数据。如果A事务发生回滚,就会导致B事务出现脏读情况。
2、ReadCommitted(Read-Committed即读取已提交):事务A修改数据,但是事务未提交;事务B中查到事务A中原始的数据。如果A事务提交后,就会导致B事务在不同时刻读取的值不一致。这就是不可重复读。
3、RepeatableRead(Repeatable-Read即可重复读取):读取数据的事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务。此隔离级别可有效防止不可重复读和脏读。
4、Serializable(可串行化):提供严格的事务隔离。它要求事务序列化执行,事务只能一个接着一个地执行,不能并发执行。此隔离级别可有效防止脏读、不可重复读和幻读。

posted @ 2022-07-18 09:52  Miskey_Fu  阅读(217)  评论(0编辑  收藏  举报