术语事务指的是构成单一逻辑工作单元的操作的集合。比如:将钱从一个账户转到另一个账户就是一个事务,该事务包括分别针对每个账户的两个更新。
![]()
英文中transaction又是交易的意思,我想应该是因为事务(transaction)管理的场景首先是出现在利用银行账户进行交易(transaction)的过程中,所以计算机科学家们把数据库的这一特性称为事务(transaction)。
事务有以下几个属性:
- 原子性:事务的所有操作在数据库中要么全部正确反映出来,要么完全不反映。
- 一致性:隔离执行事务时(换言之,在没有其他事务并发执行的情况下)保持数据库的一致性。
- 隔离性: 尽管多个事务可能并发执行,但系统保证,对于任何一对事务Ti和Tj,在Ti看来,Tj或者在Ti开始之前已经执行完成,或者在Ti完成之后开始执行。因此,每一个事务都感觉不到系统中有其他事务在并发执行。
- 持久性:一旦事务执行成功,它对数据库的改变必须是永久的——即一个可能出现的系统故障不应该导致数据库忽略成功完成的事务。
这些性质通常成为ACID特性,这一缩写来自四条性质的首字母。
在NodeJS中我们可以借助ORM框架来方便地实现事务操作,这里用bookshelf.js来举例说明。
bookshelf.js是一个基于knex.js的Node.js ORM框架,支持PostgreSQL,MySQL和SQLite3
简单来说,Bookself是一个优秀的代码库,它易于阅读、理解、可扩展。它不强制你使用任何特定的校验scheme,而是提供灵活有效的关系或嵌套关系加载策略,一级类支持事务。它是一个精益的对象关系映射器(lean Object Relation Mapper&