NoSQL简要数据库
前言
NoSQL:not only SQL(不No SQL啊),它的意思是:在关系数据库中使用关系数据库时适用,但在关系数据库中不适合本地使用其它数据库。NoSQL了弥补关系型数据库的不足,能够算是关系型数据库的一个补充吧。
可是必须明确一点。NoSQL不是为了代替关系型数据库。也无法代替关系型数据库,它和关系型数据库是各有长处的。
和关系型数据库的比較
要解说NoSQL数据库。必定要先讲一下传统的关系型数据库。关系型数据库的长处:
1、通用型、高性能。关系型数据库是被设计成能够解决大部分的应用需求的。
2、数据一致性。
3、数据更新开销小。
4、能够join(join是指表连接)
关系型数据库的不足:
1、大量数据的写入。
2、数据更新可能造成表结构的变更。关系型数据库是要预定义好表的。所以数据结构一旦有变更就要连带变更整个表,以及相关的索引等,代价很高。
3、字段不固定的应用。假设一个应用的字符无法确定,那么在设计数据库表的时候就会很棘手。
4、简单查询。关系型数据库每次查询都要经历一些列复杂的操作。这对于一些简单的查询显然会造成性能的低下。
NoSQL的长处:
1、易于数据的分散。
2、更easy通过提升提升规模而提高性能。
NoSQL更易于通过多台便宜server组建集群。从而减少成本。
所以利用NoSQL数据库非常easy实现高性能、更加灵活的数据库系统。
分类
以下介绍下NoSQL的分类。
NoSQL能够大致分为以下三类:
1、键值存储。
最常见的一类,也就是通过键-值对来存储数据。这一类又能够分为暂时性(memcached)、永久性(Flare等)、两者兼具(redis)三类。
当中暂时性是把数据存储到内存中。这样假设机器重新启动数据就会所有丢失。
永久性则能够把数据存储在磁盘等持久性存储介质中。
2、面向文档的数据库。
这样的数据库的特点是不须要定义表结构就能够直接存储数据。同一时候支持复杂的查询条件。MongoDB就是属于这样的类型。
3、面向列的数据库。主要是和面向行的相比較(如今的主流数据库比方关系型数据库都是面向行的),有扩展性的长处,在处理大量数据的时候比較有优势。
可是这样的类型的数据库应用起来比較困难。HBase就是这样的类型的数据库。
用例
以下简介几个NoSQL数据库的用例。
1、memcached。memcached最常见的使用方法就是作为缓存了。能够把memcached作为关系型数据库和应用程序之间的中间层,并把关系型数据库中经常使用的数据保存在memcached中。同一时候,也能够把memcached作为音乐文件等文件的缓存。
2、redis。不同于memcached。redis是能够作为一个完整的数据库来使用的。redis的一个典型应用就是weibo系统,redis能够使实现数据的快速读写,同一时候数据的存储具有非常高的灵活性,非常适合微博这种应用。新浪微博就用到了redis。redis在微博系统中的应用能够參考:http://blog.csdn.net/l1902090/article/details/36203749
版权声明:本文博客原创文章,博客,未经同意,不得转载。
NoSQL简要数据库的更多相关文章
- .NET平台开源项目速览(3)小巧轻量级NoSQL文件数据库LiteDB
今天给大家介绍一个不错的小巧轻量级的NoSQL文件数据库LiteDB.本博客在2013年也介绍过2款.NET平台的开源数据库: 1.[原创]开源.NET下的XML数据库介绍及入门 2.[原创]C#开源 ...
- NoSQL,关系型数据库,行列数据库对比、类比
数据库对比.类比 关系型数据库.NoSQL 关系型数据库 表与表之间有关系.表存储一些格式化的数据结构,每个元组字段的组成都一样,这样便于表之间的联结操作.不过也限制了其性能瓶颈. 更支持SQL,支持 ...
- levelDB数据库使用及实例 - 高性能nosql存储数据库
LevelDB是google公司开发出来的一款 超高性能kv存储引擎,以其惊人的读性能和更加惊人的写性能在轻量级nosql数据库中鹤立鸡群. 此开源项目目前是支持处理十亿级别规模Key-Value型数 ...
- 什么时候该使用NoSQL存储数据库?
原文地址:http://www.jdon.com/39240 文章总结以下几点:1.频繁写,很少读统计数据,比如点击率,应该使用基于内存的in-memory的key/value存储数据库如Redis, ...
- BDB (Berkeley DB)简要数据库(转载)
使用最近DBD.然后搜了下相关资料,首先公布的是一门科学: 转会http://www.javaeye.com/topic/202990 DB综述DB最初开发的目的是以新的HASH訪问算法来取代旧的hs ...
- neo4j nosql图数据库学习
neo4j 文档:https://neo4j.com/docs/getting-started/current/cypher-intro/ 1.索引 # 给某类标签节点的属性添加索引 CREATE I ...
- Expo大作战(十六)--expo结合firebase 一个nosql数据库(本章令我惊讶但又失望!)
简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网 我猜去全部机翻+个人 ...
- .NET平台开源项目速览(7)关于NoSQL数据库LiteDB的分页查询解决过程
在文章:这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑) 与 .NET平台开源项目速览(3)小巧轻量级NoSQL文件数据库LiteDB中,介绍了LiteDB的基本使用情况以及部 ...
- 10个出色的NoSQL数据库
http://www.infoq.com/research/nosql-databases?utm_source=infoqresearch&utm_campaign=lr-homepage ...
随机推荐
- (zz)Linux下Gcc生成和使用静态库和动态库详解
http://blog.chinaunix.net/uid-23592843-id-223539.html
- QT模态对话框用法(在UI文件中设置Widget背景图,这个图是一个带阴影边框的图片——酷)
QT弹出模态对话框做法: 1.新建UI文件时,一定要选择基类是QDialog的,我的选择是:Dialog without Buttons(),如下图: 2.然后在使用的时候: MyDialog dlg ...
- QT学习 之 QwtPlot(数学绘图)
QT对于统计图像.函数图像等的绘制是没有相关组件的帮助的,只有利用手工绘制图片. QwtPlot是用来绘制二维图像的widget,继承自QFrame 和 QwtPlotDict.不过严格的说来,它只是 ...
- 啊上班的二号i将诶
http://www.huihui.cn/share/8112372 http://www.huihui.cn/share/8112363 http://www.huihui.cn/share/811 ...
- 最全的LBS手机定位技术说明
随着手机技术的发展定位方式也发生了非常大的变化.获取手机位置有非常多种方式. 第一种:CELL-ID定位原理 通过移动网络获取设备当前所在的Cell信息来获取设备当前位置.当设备位置更新设备会向当前服 ...
- 【课程分享】深入浅出嵌入式linux系统移植开发 (环境搭建、uboot的移植、嵌入式内核的配置与编译)
深入浅出嵌入式linux系统移植开发 (环境搭建.uboot的移植.嵌入式内核的配置与编译) 亲爱的网友,我这里有套课程想和大家分享,假设对这个课程有兴趣的,能够加我的QQ2059055336和我联系 ...
- Jquery 实现动态加入table tr 和删除tr 以及checkbox的全选 和 获取加入TR删除TR后的数据
关于jquery实现动态加入table tr的问题我也不多说了 上面代码非常多地方都有凝视的 关于返回的 编辑后的table 数据 我这里想说的是我直接把他保存成一个连接起来的字符串了 格式 str= ...
- for循环语句之棋盘放粮食、百鸡百钱、纸张的折叠问题
1.棋盘放粮食 ; ; i < ; i++) { ; ; j <= i; j++) { x = x * ; } lszl = lszl + x; } double zl = lszl * ...
- python写的屏保程序
__author__ = 'ChenYan' from random import randint from tkinter import * class Randball(): def __init ...
- Chapter 6 装饰模式
修饰模式,是面向对象编程领域中,一种动态地往一个类中添加新的行为的设计模式.就功能而言,修饰模式相比生成子类更为灵活,这样可以给某个对象而不是整个类添加一些功能. 例如:DataOutputStrea ...