数据库事务的四个基本性质(ACID)?
2016-07-21 12:48
218 查看
数据库事务概念
什么是数据库事务?事务(transaction)是由指逻辑上对数据的的一组操作, 这组操作要么一次全部成功,如果这组操作全部失败,是不可分割的一个工作单位。
数据库事务的四个基本性质(ACID)
1. 原子性(Atomicity)
事务的原子性是指事务是一个不可分割的工作单位,这组操作要么全部发生,否则全部不发生。
2. 一致性(Consistency)
在事务开始以前,被操作的数据的完整性处于一致性的状态,事务结束后,被操作的数据的完整性也必须处于一致性状态。
拿银行转账来说,一致性要求事务的执行不应改变A、B 两个账户的金额总和。如果没有这种一致性要求,转账过程中就会发生钱无中生有,或者不翼而飞的现象。事务应该把数据库从一个一致性状态转换到另外一个一致性状态。
3. 隔离性(Isolation)
事务隔离性要求系统必须保证事务不受其他并发执行的事务的影响,也即要达到这样一种效果:对于任何一对事务T1 和 T2,在事务 T1 看来,T2 要么在 T1 开始之前已经结束,要么在 T1 完成之后才开始执行。这样,每个事务都感觉不到系统中有其他事务在并发地执行。
4. 持久性(Durability)
一个事务一旦成功提交,它对数据库的改变必须是永久的,即便是数据库发生故障也应该不回对其产生任何影响。
相关文章推荐
- 【SQL Server 批量插入数据】
- mysql创建一个改变固定字段才更新时间的时间戳timestamp
- MySQL 视图 总结
- mysql之将表中的明文变为MD5
- 实施逻辑复制软件时对目的端数据库的字符集(排序规则)的要求
- 源码-PL/SQL从入门到精通-第十二章-异常处理机制-Part 2
- mongodb learn
- mysql 中 SQL_CALC_FOUND_ROWS 功能
- 2016 07 21
- Redis 学习笔记4: Redis 3.2.1 集群搭建
- mysql记录根据日期字段倒序输出
- Redis 学习笔记4: Redis 3.2.1 集群搭建
- Redis 学习笔记4: Redis 3.2.1 集群搭建
- redis高可用主从复制
- mysql存储过程注意
- MySQL主从复制
- ORACLE在线重定义
- rman 备份恢复
- hibernate向mysql插入数据后,得到该条数据主键的方法
- mysql 的max_connections和max_user_connections 的区别