数据库事务和锁

2016-03-20  本文已影响982人  环球探测

参考链接:
MySQL中Innodb的事务隔离级别和锁的关系

1. 事务

事务:事务是作为单个逻辑单元工作执行的一些列操作。可以是一条SQL语句,也可以是多条。

ACID:事务具有四个特性:

隔离级别:事务由低到高可以分为4个隔离级别:

QQ截图20160320233510.png

事务一般是由事务日志实现的。
浅谈SQL Server中的事务日志和三种恢复模式

2. 锁

共享锁和排他锁:在一般的应用中,为了应付大量并发,我们一般使用一次封锁法,在方法的开始阶段,已经预先知道会用到哪些数据,然后全部锁住,在方法运行之后,再全部解锁。在这种方法在数据库中却不适用,因为在事务开始阶段,数据库并不知道会用到哪些数据。数据库遵循的是两段锁协议,将事务分成两个阶段,加锁阶段和解锁阶段(所以叫两段锁)。

大多数数据库的MVCC通过对数据版本的乐观锁实现。何谓数据版本?即为数据增加一个版本标识,在基于数据库表的版本解决方案中,一般是通过为数据库表增加一个 “version” 字段来实现。读取出数据时,将此版本号一同读出,之后更新时,对此版本号加一。此时,将提交数据的版本数据与数据库表对应记录的当前版本信息进行比对,如果提交的数据版本号大于数据库表当前版本号,则予以更新,否则认为是过期数据。

上一篇下一篇

猜你喜欢

热点阅读