数据库系统中数据的一致性是指什么

请问:数据库系统中数据的一致性是指什么?

数据一致性通常指关联数据之间的逻辑关系是否正确和完整。而数据存储的一致性模型则可以认为是存储系统和数据使用者之间的一种约定。如果使用者遵循这种约定,则可以得到系统所承诺的访问结果
常用的一致性模型有:
a、严格一致性(linearizability,
strict/atomic
Consistency):读出的数据始终为最近写入的数据。这种一致性只有全局时钟存在时才有可能,在分布式网络环境不可能实现。
b、顺序一致性(sequential
consistency):所有使用者以同样的顺序看到对同一数据的操作,但是该顺序不一定是实时的。
c、因果一致性(causal
consistency):只有存在因果关系的写操作才要求所有使用者以相同的次序看到,对于无因果关系的写入则并行进行,无次序保证。因果一致性可以看做对顺序一致性性能的一种优化,但在实现时必须建立与维护因果依赖图,是相当困难的。
d、管道一致性(PRAM/FIFO
consistency):在因果一致性模型上的进一步弱化,要求由某一个使用者完成的写操作可以被其他所有的使用者按照顺序的感知到,而从不同使用者中来的写操作则无需保证顺序,就像一个一个的管道一样。
相对来说比较容易实现。
e、弱一致性(weak
consistency):只要求对共享数据结构的访问保证顺序一致性。对于同步变量的操作具有顺序一致性,是全局可见的,且只有当没有写操作等待处理时才可进行,以保证对于临界区域的访问顺序进行。在同步时点,所有使用者可以看到相同的数据。
f、
释放一致性(release
consistency):弱一致性无法区分使用者是要进入临界区还是要出临界区,
释放一致性使用两个不同的操作语句进行了区分。需要写入时使用者acquire该对象,写完后release,acquire-release之间形成了一个临界区,提供
释放一致性也就意味着当release操作发生后,所有使用者应该可以看到该操作。
g、最终一致性(eventual
consistency):当没有新更新的情况下,更新最终会通过网络传播到所有副本点,所有副本点最终会一致,也就是说使用者在最终某个时间点前的中间过程中无法保证看到的是新写入的数据。可以采用最终一致性模型有一个关键要求:读出陈旧数据是可以接受的。
h、delta
consistency:系统会在delta时间内达到一致。这段时间内会存在一个不一致的窗口,该窗口可能是因为log
shipping的过程导致。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2009-01-02
我的书上只有完整性的概念,你说的一致性应该是完整性的一个方面,就是一个数据元素一次修改就行了,不会出现这里修改过了,另一个表还有没修改的数据(日志数据除外)。
第2个回答  推荐于2017-11-26
简单说来就是一条column的数据在多个表中保持同步更新, 一般用foreign key实现mapping. 比如两张表table1,table2, 其中table1的uid column是primary key, table2的uid column是foreign key, 则当修改table1的uid column的一row时,table2的对应row也会自动更新.本回答被提问者采纳
第3个回答  2019-07-09
就是数据修改前后必须保持一致
比如有两个表(员工\职位),员工表中有员工代码、姓名、职位代码等属性,职位表中有职位代码、职位名称、职位等级等属性。你在其中员工表中进行了插入操作,你插入了一个新员工的信息,而这个新员工的职位是公司新创建的一个职位。如果没有一致性的保证,就会出现有这么一个员工,但是不知道他到底担当什么职责!
第4个回答  2019-01-29
应该是你上一次做的申报流程没有走完.
相似回答