事务在英文中是transaction,和现实世界中的交易很类似,它有如下四个特性:

1、A (Atomicity) 原子性
原子性很容易理解,也就是说事务里的所有操作要么全部做完,要么都不做,事务成功的条件是事务里的所有操作都成功,只要有一个操作失败,整个事务就失败,需要回滚。

比如银行转账,从A账户转100元至B账户,分为两个步骤:1)从A账户取100元;2)存入100元至B账户。这两步要么一起完成,要么一起不完成,如果只完成第一步,第二步失败,钱会莫名其妙少了100元。

2、C (Consistency) 一致性
一致性也比较容易理解,也就是说数据库要一直处于一致的状态,事务的运行不会改变数据库原本的一致性约束。

例如现有完整性约束a+b=10,如果一个事务改变了a,那么必须得改变b,使得事务结束后依然满足a+b=10,否则事务失败。

3、I (Isolation) 独立性
所谓的独立性是指并发的事务之间不会互相影响,如果一个事务要访问的数据正在被另外一个事务修改,只要另外一个事务未提交,它所访问的数据就不受未提交事务的影响。
比如现有有个交易是从A账户转100元至B账户,在这个交易还未完成的情况下,如果此时B查询自己的账户,是看不到新增加的100元的。

4、D (Durability) 持久性
持久性是指一旦事务提交后,它所做的修改将会永久的保存在数据库上,即使出现宕机也不会丢失。

最新文章

  1. SharePoint 2013: A feature with ID has already been installed in this farm
  2. Entity Framework 6连接Postgresql、SQLite、LocalDB的注意事项和配置文件
  3. 输入框三种输入方式(selenium webdriver 干货)
  4. 四则运算的实现(C++)重做
  5. python中常用的函数与库一
  6. Java学习路线图
  7. Method Swizzling和AOP(面向切面编程)实践
  8. NDK各版本下载
  9. 高速公路(Highway,ACM/ICPC SEERC 2005,UVa1615)
  10. iOS中scrollview是否要回弹
  11. Linux驱动设计——并发与竞态控制
  12. sphinx 占用大量内存
  13. 【Linux】鸟哥的Linux私房菜基础学习篇整理(三)
  14. LintCode-乘积最大子序列
  15. (Problem 3)Largest prime factor
  16. mobiscroll 插件札记(一)
  17. Upgrade with the Gradle Wrapper, gradlew升级
  18. 关于vue的混入使用
  19. python基础知识点三
  20. rsync排除多个文件实现同步

热门文章

  1. windows下批量杀死进程
  2. 1042. Shuffling Machine (20) - sstream实现数字转字符串
  3. spring-data-mongodb必须了解的操作
  4. Android Xfermode 实战 实现圆形、圆角图片
  5. http status 源码
  6. Jmail组件发送邮件说明ASP.NET
  7. 多重和嵌套if
  8. 用C#代码控制水晶报表中的对象
  9. Java中构造方法的执行顺序
  10. hdu find the safest road