NoSQL
2016-02-08 20:23
246 查看
理解ACID与BASE的区别(ACID是关系型数据库强一致性的四个要求,而BASE是NoSQL数据库通常对可用性及一致性的弱要求原则,它们的意思分别是,ACID:atomicity, consistency, isolation, durability;BASE:Basically Available, Soft-state, Eventually Consistent。同时有意思的是ACID在英语里意为酸,BASE意思为碱)
理解持久化与非持久化的区别。这么说是因为有的NoSQL系统是纯内存存储的。
你必须意识到传统有关系型数据库与NoSQL系统在数据结构上的本质区别。传统关系型数据库通常是基于行的表格型存储,而NoSQL系统包括了列式存储(Cassandra)、key/value存储(Memcached)、文档型存储(CouchDB)以及图结构存储(Neo4j)
与传统关系数据库有统一的SQL语言操作接口不同,NoSQL系统通常有自己特有的API接口。
在架构上,你必须搞清楚,NoSQL系统是被设计用于成百上千台机器的集群中的,而非共享型数据库系统的架构。
在NoSQL系统中,可能你得习惯一下不知道你的数据具体存在何处的情况。
在NoSQL系统中,你最好习惯它的弱一致性。”eventually consistent”(最终一致性)正是BASE原则中的重要一项。比如在Twitter,你在Followers列表中经常会感受到数据的延迟。
在NoSQL系统中,你要理解,很多时候数据并不总是可用的。
你得理解,有的方案是拥有分区容忍性的,有的方案不一定有。
理解持久化与非持久化的区别。这么说是因为有的NoSQL系统是纯内存存储的。
你必须意识到传统有关系型数据库与NoSQL系统在数据结构上的本质区别。传统关系型数据库通常是基于行的表格型存储,而NoSQL系统包括了列式存储(Cassandra)、key/value存储(Memcached)、文档型存储(CouchDB)以及图结构存储(Neo4j)
与传统关系数据库有统一的SQL语言操作接口不同,NoSQL系统通常有自己特有的API接口。
在架构上,你必须搞清楚,NoSQL系统是被设计用于成百上千台机器的集群中的,而非共享型数据库系统的架构。
在NoSQL系统中,可能你得习惯一下不知道你的数据具体存在何处的情况。
在NoSQL系统中,你最好习惯它的弱一致性。”eventually consistent”(最终一致性)正是BASE原则中的重要一项。比如在Twitter,你在Followers列表中经常会感受到数据的延迟。
在NoSQL系统中,你要理解,很多时候数据并不总是可用的。
你得理解,有的方案是拥有分区容忍性的,有的方案不一定有。
关系型数据库遵循ACID规则
事务在英文中是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) 持久性 持久性是指一旦事务提交后,它所做的修改将会永久的保存在数据库上,即使出现宕机也不会丢失。
相关文章推荐
- 【翻译自mos文章】将Oracle 12c数据库从标准版convert到企业版
- 【翻译自mos文章】Oracle Database 12c Standard Edition 2 (12.1.0.2)
- 造轮子:取SQL分组中某几行数据
- ADO.NET之二进制存取图片
- 阿里分布式数据库服务实践
- C++自制Redis数据库(七) 决战架构设计--从数据的角度贯通始终,表白我的心。
- ADO.NET之存储图片路径
- 【翻译自mos文章】在windows平台上怎么启用Oracle database 企业版的partition?
- mac环境下手动卸载mysql
- ADO.NET之数据库表之间批量写入数据
- JavaWeb项目连接Oracle数据库
- mysql 结果集合切换
- ADO.NET之利用存储过程录入数据
- mysql
- Redis缓存服务器Java客户端Jedis2.8 demo
- ADO.NET之command录入数据-视图同步更新
- 造轮子:SQL拼接方法
- 08. mybatis 高级:动态sql批量插入数据
- 03. mybatis 动态sql && 模糊查询
- Django工程读取mongodb并使用分页器