ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

如何理解事务一致性?

2020-12-05 15:34:14  阅读:208  来源: 互联网

标签:解释 事务 AB 5000 数据库 理解 一致性


何为一致性?

初学数据库事务时老师讲到数据库四大特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。

原子性和持久性概念基本秒懂,隔离性也好理解。但这个一致性实在让人摸不着头脑。什么和什么一致?体现在哪里?

先看看官方的套娃解释:一致性是指事务必须使数据库从一个一致性状态变换到另一个一致性状态,也就是说一个事务执行之前和执行之后都必须处于一致性状态。

我让你解释一致性,你又拿一致性来解释一致性。这不是在套娃吗?

于是百度了一下,发现好多半吊子博主,把原子性的解释套在一致性上,自己满脑子浆糊,还大言不惭的误人子弟。

还有些博主估计段位太高,不屑把话说的太明白,他们是这么解释一致性的:“一致性是指数据处于一种语义上的有意义且正确的状态。一致性是对数据可见性的约束,保证在一个事务中的多次操作的数据中间状态对其他事务不可见的。因为这些中间状态,是一个过渡状态,与事务的开始状态和事务的结束状态是不一致的。”

我反正是更晕了。

于是继续百度之,有人用AB转账举例,A账户总共5000元,不论怎么他怎么给B转,AB账户合计总额还是5000.这就是一致性。貌似有些意思了,但终归感觉说的不是很透彻。

最后终于看到了一句解释点醒了我。原话忘了,但含义总结如下:

所谓一致性是数据库处理前后结果应与其所抽象的客观世界中真实状况保持一致。这种一致性是一种需要管理员去定义的规则。管理员如何指定规则,数据库就严格按照这种规则去处理数据。

就拿那个老掉牙的AB转账来进一步解释,如果说AB账户总金额5000就是数据库的一致性规则,那么我能不能把A账户转走10000给B,让B账户有10000,而A剩下-5000?从数学上来看完全正确,但这显然是不符合常理的。而这种常理,就是所谓的一致性。

你悟了吗?


标签:解释,事务,AB,5000,数据库,理解,一致性
来源: https://blog.csdn.net/c0d5r/article/details/110680789

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有