MongoDB使用C++语言编写的一个基于分布式的文件存储的开源数据库。可以在承受高负载的情况下,保证服务器的性能。

MongoDB将数据存储成为一个文档,数据结构有键值对组成。类似于JSON,字段值可以包含其它文档。

特点:

  1. 操作简单
  2. 可以通过本地或网络创建数据库镜像,增强了可扩展性
  3. 允许执行服务器脚本。
  4. 支持多种语言

MongoDB的下载地址:https://www.mongodb.com/download-center#community

MongoDB的管理工具:

  1. Fang of Mongo
  2. Mongo3
  3. MongoHub
  4. Opricot//基于浏览器的控制台
  5. Database Master//windows的管理工具
  6. RockMongo //轻量级,支持多国语言

MongoDB与SQL概念对比

SQL术语/概念 MongoDB术语/概念 解释/说明
database database 数据库
table collection 数据库表/集合
row document 数据记录行/文档
column field 数据字段/域
index index 索引
table joins   表连接/MongoDB不支持
primary key primary key 主键/MongoDB自动将_id字段设置为主键

MongoDB的数据类型

数据类型 描述
String 字符串。存储数据常用的数据类型。在 MongoDB 中,UTF-8 编码的字符串才是合法的。
Integer 整型数值。用于存储数值。根据你所采用的服务器,可分为 32 位或 64 位。
Boolean 布尔值。用于存储布尔值(真/假)。
Doubles 双精度浮点值。用于存储浮点值。
Min/Max keys 将一个值与 BSON(二进制的 JSON)元素的最低值和最高值相对比。
Arrys 用于将数组或列表或多个值存储为一个键。
Timestamp 时间戳。记录文档修改或添加的具体时间。
Object 用于内嵌文档。
Null 用于创建空值。
Symbol 符号。该数据类型基本上等同于字符串类型,但不同的是,它一般用于采用特殊符号类型的语言。
Date 日期时间。用 UNIX 时间格式来存储当前日期或时间。你可以指定自己的日期时间:创建 Date 对象,传入年月日信息。
Object ID 对象 ID。用于创建文档的 ID。
Binary Data 二进制数据。用于存储二进制数据。
Code 代码类型。用于在文档中存储 JavaScript 代码。
Rgular expression 正则表达式类型。用于存储正则表达式。

语法:

  • use DATABASENAME:如果数据库不存在则创建从数据库,否则切换到指定数据库
  • show dbs:查看所有数据库。没有数据的数据库不会显示。
  • db.dropDatabase():删除数据库
  • db.clolection.drop():删除集合
  • db.COLLICTION_NAME.insert(document):向指定集合中插入文档,使用save()也行。如果集合名不在数据库中,则创建
  • db.collection.remove(删除条件):移除文档。
  • dbCOLLECTION_NAME.find(query,projection)/findOne():查询文档。query : 可选,使用查询操作符指定查询条件projection使用投影操作符指定返回的键。后加pretty()是格式化显示文档的意思

MongoDB和关系型数据库的条件语句比较

操作 格式 MongoDB范例 关系型数据库范例
等于 {<key>:<value>} db.col.find({"by":"abc"}).pretty() where by = 'abc'
小于 {<key>:<$lt:value>} db.col.find({"likes":{$lt:20}}).pretty() where likes < 50
小于等于 {<key>:<$lte:value>} db.col.find({"likes":{$lte:20}}).pretty() where likes < =50
大于 {<key>:<$gt:value>} db.col.find({"likes":{$gt:20}}).pretty() where likes > 50
大于等于 {<key>:<$gte:value>} db.col.find({"likes":{$gte:20}}).pretty() where likes >= 50
不等于 {<key>:<$ne:value>} db.col.find({"likes":{$ne:20}}).pretty() where likes != 50

2017-06-01

如果需要在数据库中读取指定数量的数据记录,可使用Limit(NUMBER).语法:number就是安装条件查询后要显示的文档个数。

难点:db.col.find({},{"title":1}).limit(1)

  • 第一个{}放查询条件,控制表示返回所有文档
  • 第二个{}指定那些列显示或不显示,0:不显示,1:显示

如果需要在数据库中读取指定数量之外的数据记录,可使用Skip(NUMBER).

db.col.find({},{"title":1}).skip(5).limit(1)跳过前五条数据显示后一条数据。可以用来实现分页。

使用Sort(KEY:1/-1)对数据进行排序。1表示升序 -1 表示降序。key表示排序字段。

索引通常能够极大的提高查询的效率。索引是特殊的数据结构,索引存储在一个易于遍历读取的数据集合中,索引是对数据库表中一列或多列的值进行排序的一种结构。

mongodb使用ensureIndex({KEY:1/-1})创建以KEY字段为准的索引。并以升序或降序的方式排列。可以使用多个字段(关系型数据库中称作复合索引)。eg:

db.col.ensureIndex({"title":1,"description":-1})

创建索引可接受的可选参数图下表:

参数 类型 描述
background Boolean 建索引过程会阻塞其它数据库操作,background可指定以后台方式创建索引,即增加 "background" 可选参数。 "background" 默认值为false
unique Boolean 建立的索引是否唯一。指定为true创建唯一索引。默认值为false.
name string 索引的名称。如果未指定,MongoDB的通过连接索引的字段名和排序顺序生成一个索引名称
dropDups Boolean 在建立唯一索引时是否删除重复记录,指定 true 创建唯一索引。默认值为 false
sparse Boolean 对文档中不存在的字段数据不启用索引;这个参数需要特别注意,如果设置为true的话,在索引字段中不会查询出不包含对应字段的文档.。默认值为 false.
expireAfterSeconds int 指定一个以秒为单位的数值,完成 TTL设定,设定集合的生存时间
v index version 索引的版本号。默认的索引版本取决于mongod创建索引时运行的版本
weights document 索引权重值,数值在 1 到 99,999 之间,表示该索引相对于其他索引字段的得分权重。
default_languge string 对于文本索引,该参数决定了停用词及词干和词器的规则的列表。 默认为英语
language_override string 对于文本索引,该参数指定了包含在文档中的字段名,语言覆盖默认的language,默认值为 language.

2017-06-08

db.COLLECTION_NAME.find().sort({KEY:1})排序。
key是字段名,1表示升序,-1表示降序

NoSQL学习1的更多相关文章

  1. NOSQL学习笔记系列之MongoDB 一 基础

    主题:MongoDB 学习资料参考网址: 1.http://www.w3cschool.cc/mongodb/mongodb-tutorial.html 2.http://www.icoolxue.c ...

  2. Hadoop、Pig、Hive、Storm、NOSQL 学习资源收集

    (一)hadoop 相关安装部署 1.hadoop在windows cygwin下的部署: http://lib.open-open.com/view/1333428291655 http://blo ...

  3. Hadoop、Pig、Hive、NOSQL 学习资源收集

    转自:http://www.cnblogs.com/zzjhn/p/3855566.html (一)hadoop 相关安装部署 1.hadoop在windows cygwin下的部署: http:// ...

  4. NoSQL学习二:MongoDB基本管理命令

    MongoDB命令学习  一.MongoDB命令帮助 在安装MongoDB后,启动服务器进程(mongod),可以通过在客户端命令mongo实现对MongoDB的管理和监控: 这是MongoDB最上层 ...

  5. NoSQL学习一:MongoDB下载与安装

    MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的.他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型.M ...

  6. nosql学习一

    1.NoSQL,泛指非关系型的数据库.随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不从心,暴露了很多难 ...

  7. NoSQL学习——MongoDB

    MongoDB作为一款文档数据库,支持分片存储,scale-out,集群自动切换,下面将粗略的配置步骤总结如下: 几个重要概念: 数据库:集合--记录--游标(查询时标记序号) sharding分片: ...

  8. Nosql学习笔记

    1.利用Query查询,Query操作只搜索主键属性值,并支持对键属性值使用部分比较运算符,以优化搜索过程. * 查询结果始终按范围键排序.如果范围键的数据类型是数字,则会按数字顺序返回结果:否则,会 ...

  9. NOSQL学习之二:MongoDB

    MongoDB是一个高性能,开源,无模式的文档型数据库,它在许多场景下可用于替代传统的关系型数据库或键/值存储方式,是当前NoSQL数据库中比较热门的一种. MongoDB使用C++开发.不支持SQL ...

随机推荐

  1. eclipse web项目没有run on server

    如下图,将 Dynamic Web Module和Java勾选上

  2. 串口转以太客户端(增加uci、可连接多个服务器)

    1. 进入barrier_breaker/package/utils文件夹,新建ttl_client 2. 该目录下的Makefile # # Copyright (C) OpenWrt.org # ...

  3. Vivado HLS初识---阅读《vivado design suite tutorial-high-level synthesis》(6)

    Vivado HLS初识---阅读<vivado design suite tutorial-high-level synthesis>(6) 1.创建工程与开启GUI 2.调试 查看关于 ...

  4. position 分层固定在屏幕某位置

    很多网站我们看到在屏幕右下角有一个,返回顶部,始终在那儿,还有些网站顶部菜单栏永远也是固定的不动,就是通过今天学习的position来做的. 在style中加入 positon:fixed;top 0 ...

  5. windebug 与 office Home

    https://officecdn.microsoft.com/sg/492350f6-3a01-4f97-b9c0-c7c6ddf67d60/media/zh-CN/HomeStudentRetai ...

  6. ALGO-10_蓝桥杯_算法训练_集合运算(排序)

    问题描述 给出两个整数集合A.B,求出他们的交集.并集以及B在A中的余集. 输入格式 第一行为一个整数n,表示集合A中的元素个数. 第二行有n个互不相同的用空格隔开的整数,表示集合A中的元素. 第三行 ...

  7. java设计模式-Observer(2)

    一.模拟AWT事件处理 回顾一下JDK里面按下一个Button,有件事发生,这个东西怎么写: package com.cy.dp.observer.awt; import java.awt.Butto ...

  8. PAT 甲级 1011 World Cup Betting (20)(20 分)

    1011 World Cup Betting (20)(20 分)提问 With the 2010 FIFA World Cup running, football fans the world ov ...

  9. PAT 乙级 1031 查验身份证(15) C++版

    1031. 查验身份证(15) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 一个合法的身份证号码由17位地区. ...

  10. 得到body相对定位的插件

    相对body定位的插件 function offset(ele){ //该元素到父级水平定位的距离 var le=ele.offsetLeft; //该元素到父级垂直定位的距离 var to=ele. ...