『壹』 nosql数据库库和sql数据库的区别
一、概念
SQL(StructuredQueryLanguage)数据库,指关系型数据库。主要代表:SQLServer,Oracle,MySQL(开源),PostgreSQL(开源)。
NoSQL(NotOnlySQL)泛指非关系型数据库。主要代表:MongoDB,Redis,CouchDB。
二、区别
1、存储方式
SQL数据存在特定结构的表中;而NoSQL则更加灵活和可扩展,存储方式可以省是JSON文档、哈希表或者其他方式。SQL通常以数据库表形式存储数据。举个栗子,存个学生借书数据:
4、SQL中的JOIN查询
SQL中可以使用JOIN表链接方式将多个关系数据表中的数据用一条简单的查询语句查询出来。NoSQL暂未提供类似JOIN的查询方式对多个数据集中的数据做查询。所以大部分NoSQL使用非规范化的数据存储方式存储数据。
5、数据耦合性
SQL中不允许删除已经被使用的外部数据,例如审核人表中的"熊三"已经被分配给了借阅人熊大,那么在审核人表中将不允许删除熊三这条数据,以保证数据完整性。而NoSQL中则没有这种强耦合的概念,可以随时删除任何数据。
6、事务
SQL中如果多张表数据需要同批次被更新,即如果其中一张表更新失败的话其他表也不能更新成功。这种场景可以通过事务来控制,可以在所有命令完成后再统一提交事务。而NoSQL中没有事务这个概念,每一个数据集的操作都是原子级的。
7、增删改查语法
8、查询性能
在相同水平的系统设计的前提下,因为NoSQL中省略了JOIN查询的消耗,故理论上性能上是优于SQL的。
『贰』 nosql是什么
您好
虽然关系数据库已有诸多不便,但以NoSQL目前的发展状况要代替他还为时过早,并且回至少从目前来看,答他们也各有所长,谁也替代不了谁。SQL语句的方便在许多情况下还是相当实用,SQL数据库软件的强壮程度度也是NoSQL数据库软件目前无法达到的。NoSQL在许多领域,比如高速缓存,高速消息队列方面有着传统关系数据库无法比拟的优势,他们将在今后一些年并驾齐驱,至于未来的方向还得看在实际使用和进一步开发中遇到的问题。这里有一篇译自Redis(一种近年来发展迅速的NoSQL数据库)官方网站的介绍文章,对NoSQL的特性可窥一斑。
这个要看你的应用范围、场景