数据库事务四大特征及隔离级别
来源:互联网 发布:sql count 用法 编辑:程序博客网 时间:2024/06/05 18:56
1、事务的四大特性(ACID)
⑴ 原子性(Atomicity)
原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚。因此事务的操作如果成功就必须要完全应用到数据库,如果操作失败则不能对数据库有任何影响。
⑵ 一致性(Consistency)
一致性是指事务必须使数据库从一个一致性状态变换到另一个一致性状态,也就是说一个事务执行之前和执行之后都必须处于一致性状态。
⑶ 隔离性(Isolation)
⑷ 持久性(Durability)
持久性是指一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的,即便是在数据库系统遇到故障的情况下也不会丢失提交事务的操作。2.MySQL数据库为我们提供的四种隔离级别
① Serializable (串行化):可避免脏读、不可重复读、幻读的发生。
② Repeatable read (可重复读):可避免脏读、不可重复读的发生。
③ Read committed (读已提交):可避免脏读的发生。
④ Read uncommitted (读未提交):最低级别,任何情况都无法保证。
脏读:
脏读是指在一个事务处理过程里读取了另一个未提交的事务中的数据。
当一个事务正在多次修改某个数据,而在这个事务中这多次的修改都还未提交,这时一个并发的事务来访问该数据,就会造成两个事务得到的数据不一致。
不可重复读:
不可重复读是指在对于数据库中的某个数据,一个事务范围内多次查询却返回了不同的数据值,这是由于在查询间隔,被另一个事务修改并提交了。
不可重复读和脏读的区别是,脏读是某一事务读取了另一个事务未提交的脏数据,而不可重复读则是读取了前一事务提交的数据。
虚读:
幻读是事务非独立执行时发生的一种现象。例如事务T1对一个表中所有的行的某个数据项做了从“1”修改为“2”的操作,这时事务T2又对这个表中插入了一行数据项,而这个数据项的数值还是为“1”并且提交给数据库。而操作事务T1的用户如果再查看刚刚修改的数据,会发现还有一行没有修改,其实这行是从事务T2中添加的,就好像产生幻觉一样,这就是发生了幻读。
幻读和不可重复读都是读取了另一条已经提交的事务(这点就脏读不同),所不同的是不可重复读查询的都是同一个数据项,而幻读针对的是一批数据整体(比如数据的个数)。
阅读全文
0 0
- 数据库事务四大特征及隔离级别
- 数据库事务的四大特性(ACID)及事务隔离级别
- 数据库事务的四大特性及隔离级别
- 数据库事务的四大特性及隔离级别
- 数据库事务的四大特性与隔离级别及测试
- 数据库事务 四大特性 && 隔离级别
- 数据库事务及隔离级别
- [数据库] 数据库的四大特性acid及事务的隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 数据库事务的四大特性以及事务的隔离级别
- 前端技术介绍,跟我学响应式布局
- 关于pod导入protocolBuffers使用问题
- Leetcode 605 Can Place Flowers
- 1464:最低等级
- 字典树--Xor问题
- 数据库事务四大特征及隔离级别
- uva 11582 lrj-P316 斐波那契大数
- HBase 2.0 新特性& HBaseCon Asia 2017 参会总结
- C# Winform实现捕获窗体最小化、最大化、关闭按钮事件的方法,可通过重写WndProc来实现
- Leetcode 665 Non-decreasing Array
- 【学习摘记】马士兵JAVASCRIPT_课时10-12_收尾及精华整理
- JEECG 3.7.1 非Maven版本源码下载,企业级JAVA快速开发平台
- Leetcode 674 Longest Continuous Increasing Subsequence
- Sql 2014 企业版 还原数据库时, 报错: 操作错误, 或 No backupset selected to be restored