跟小博老师一起学习数据库 ——NoSql

2017-05-04  本文已影响0人  博为峰51Code教研组

随着互联网不断的发展,催生了越来越多的超大型网站,这些网站要求响应速度快、并发量高,使得传统数据库难以应对。为了克服关系型数据库的瓶颈,大规模多重数据的挑战,noSql型数据库能很好的解决此类问题。

noSql全称为not only sql,是一种非关系类型数据库的统称。发展至今市场空前繁荣,IT界大佬厂商们纷纷推出自己的noSql类型数据库。

NoSql分类

根据数据库存储方式,可将市面主流NoSql类型数据库划分成四类。

键值

此类数据库采用Map(key-value)方式保存数据,一般都会用哈希表。这类型noSql数据库操作简单、使用方便。但对数据查询与更新的时候,效率相对低下。代表数据库:Redis, Voldemort, Oracle BDB。

列值

此类型数据库的键保留,和键-值类型数据库不同是,它一个键可指向多列,列又分成若干子列。代表数据库:Cassandra, HBase, Riak。

文档

它与key-value存储方式类似,用版本化的数据文档保存,可看成JSON格式。它可以嵌套键值,相对纯属键值数据库查询效率比较高。代表数据库:CouchDB, MongoDb。

图形

图形结构的数据库与其它类型有很大不同,它使用灵活的图形模型,能分布在多台服务器上。它没有标准的查询语言(SQL),要制定相应的数据模型。如:Neo4J, InfoGrid, Infinite Graph。

适用场景

noSql类型数据库还不能完全替代传统关系型数据库,它只适合以下的这几种情况下比较适用:

l数据模型比较简单

l需要灵活性更强的IT系统

l对数据库性能要求较高

l不需要高度的数据一致性

l对于给定key,比较容易映射复杂值的环境

上一篇下一篇

猜你喜欢

热点阅读