MongoDB

  • Non-relational JSON Document Store
  • 开源
  • 文档数据库Document Database
  • 自动增长(忽略 高性能、高可用性等自我评价)
  • 动态schema
  • 不支持joins

什么是Document Database

数据库中的每个记录都被看作是一个以键值对为数据结构的文档

JSON示例[value可为列表、可嵌套]

{ 'key' : 'value' ,

'key' : [ 'v1', 'v2'] ,

{} }

下载

https://www.mongodb.org/downloads

配置

解压到任意目录,修改环境变量,创建数据存储目录

Linux中部分操作如下

sudo gedit /etc/profile

添加以下内容

#mango
export MANGO_HOME=/home/kevin/mongodb
export PATH=$MANGO_HOME/bin:$PATH
source /etc/profile

创建默认数据目录并更改权限

sudo mkdir -p /data/db
sudo chown kevin /data/db

启动============下面的操作Windows和Linux相似===========

在terminal/cmd中输入mongod

如果设定其他目录,需要添加参数(如db存放目录路径中含空格,需要用双引号将路径括住),如

mongod --dbpath D:\ProgramFiles\CS\mongodb\db

看到出现“waiting for connection”后就可以确定服务开启成功(在浏览器中打开下面两个网址,第一次用看两眼,有点存在感。注意的是使用过程不要关闭该窗口)

http://localhost:27017/

http://localhost:28017/

shell中的CURD操作

打开一个新的cmd,同样切换到bin目录,输入mongo(一个javascript shell),会连接到mongod(database server),并默认使用名为test的数据库

for (var i = 1; i <= 25; i++) db.testData.insert( { x : i } )   //产生测试数据
db 显示当前数据库的名称
show dbs 列出所有数据库
use <数据库名称> 如果数据库原本不存在将会创建
show collections 列出db下的所有集合
 j = { name : "mongo" } 创建文档j
 db.testData.insert( j ) 将j插入到testData这个collection中(类似table)
db.testData.find()[.skip(n)][.limit(n)] 列出testData中的记录,默认输出前20条,需要继续输出的话要输入it
db.testData.findOne()[.pretty()] pretty可使文档更好看
db.testData.find( { x : 3 } [.sort({x:-1})]  条件搜索
db.testData.save(j) 与insert的不同之处在于,当已存在相同_id值的文档时,save会更新文档,insert则报错
db.testData.count() 文档计数
db.testData.update({"name":"mongo"},{"name":"manhua"}) 注意update是整个替换的,若多个匹配,只替换第一个,测试发现被update的会被先删除后插入,但_id不变;若要全部更新,要添加{multi: true}
db.testData.remove({"x":3}) 所有匹配的文档都被删除,若参数为{},则全部文档将逐个被删

命令进阶

{ key : { $gt : value } } 类似的还有$gte $lt $lte

 { key : { $exists : boolean } } 类似的: $upsert : true

{ arraykey : { $in : [] v1, v2, v3 } } 类似的:$all

{ $and : [ {key : value } , {key : value }] }   $or $set $unset $inc $addToSet $push $pushAll $pop

 db.RuleOut.find({"_id" : {'$regex':'...AI'} }) 或db.RuleOut.find({"_id" :/...AI/ })正则查询,对于第一种转义用\\第二种用\

访问内嵌key使用’点‘: outerKey.innerKey

更多命令参考官方文档http://docs.mongodb.org/manual/reference/method/

【有个blog写的不错,上链接】http://www.cnblogs.com/huangxincheng/category/355399.html

==============

备份与恢复

mongodump -d [数据库名称] -o [保存路径]

mongorestore -d [数据库名称] --drop [保存路径],其中drop选项是先删除原有数据库里面的数据

mongorestore -d pssp --drop dump/pssp/rule80.bson 恢复单个collection

MongoDB 快速入门的更多相关文章

  1. 前端开发小白必学技能—非关系数据库又像关系数据库的MongoDB快速入门命令(2)

    今天给大家道个歉,没有及时更新MongoDB快速入门的下篇,最近有点小忙,在此向博友们致歉.下面我将简单地说一下mongdb的一些基本命令以及我们日常开发过程中的一些问题.mongodb可以为我们提供 ...

  2. MongoDb 快速入门教程

    文章首发于[博客园-陈树义],点击跳转到原文MongoDb 快速入门教程. MongoDb 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的. 它是可扩展的 ...

  3. MongoDB快速入门指南与docker-compose快体验

    MongoDB快速入门指南与docker-compose快体验 MongoDB相对于RDBMS的优势 模式少 -MongoDB是一个文档数据库,其中一个集合包含不同的文档.一个文档之间的字段数,内容和 ...

  4. [你必须知道的NOSQL系列]专题一:MongoDB快速入门

    一.前言 现在越来越多的公司开始采用非关系数据库了,并且很多公司的面试都要求面试者有MongoDB的使用经验,至于非关系数据库与关系型数据库之间的区别大家可以自行百度.但是作为程序员的我们,既然大部分 ...

  5. MongoDB学习(五)使用Java驱动程序3.3操作MongoDB快速入门

    [引言] 毕竟现在MongoDB还是出于成长阶段,所以现在网上相关的资料很少,而且大部分还都是针对于MongoDB的老版本的.再加上MongoDB的频繁升级.重大更新等等,导致菜鸟学习的难度增大. 好 ...

  6. MongoDB快速入门教程 (3.2)

    3.2.索引 索引是特殊的数据结构,索引存储在一个易于遍历读取的数据集合中,建立索引,通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条 ...

  7. 前端开发必学技能之一———非关系数据库又像关系数据库的MongoDB快速入门第一步下载与安装

    数据库总的来说,分为两个方向:关系数据库和非关系数据库.我们常见的MySQL.Oracle.SQLSerever以及IBMDB2都是属于关系数据库,这里的关系值得是二维表的结构,但是由于随着web的应 ...

  8. MongoDB 快速入门--高级

    引用 --------->DBRefs DBRef的形式: { $ref : , $id : , $db : } $ref:集合名称 $id:引用的id $db:数据库名称,可选参数 { &qu ...

  9. MongoDB 快速入门--中级

    索引 ensureIndex 用来创建索引,需要注意的就是一个集合最多也就64个索引 如果没加所有就是表扫表,速度很慢, 当然如果索引的键有多个,就必须考虑顺序 拓展索引 同样的也可以为内嵌文档 建立 ...

  10. MongoDB 快速入门--初级

    数据库的操作一般来说都是CRUD,这其中最难的就是查询,所有所我们先来了解MongoDB中的 插入(insert) 说到插入,我们就必须得说说如何创建数据库,如何创建集合,然后才是如何创建文档. 在这 ...

随机推荐

  1. hdu 3721 树的直径

    思路:枚举+树的直径 #include<iostream> #include<cstring> #include<cstdio> #include<algor ...

  2. BZOJ4823 [Cqoi2017]老C的方块 【最小割】

    题目 老C是个程序员. 作为一个懒惰的程序员,老C经常在电脑上玩方块游戏消磨时间.游戏被限定在一个由小方格排成的R行C列网格上,如果两个小方格有公共的边,就称它们是相邻的,而且有些相邻的小方格之间的公 ...

  3. Gym 100971C 水&愚&三角形

    Description standard input/output Announcement   Statements There is a set of n segments with the le ...

  4. Twitter如何在数千台服务器上快速部署代码?

    答案是:用BT,也就是你我应该都很熟悉的BitTorrent. 对于网站经营者.创业者来说,扩展性的问题是在网站流量成长过程中势必会面对的问题,如何建立一个具有扩展性的架构(scalable arch ...

  5. 【08】node 之 fs文件

    var fs = require("fs");//fs 系统文件模块,对文件进行操作.Node.js 文件系统(fs 模块)模块中的方法均有异步和同步版本,例如读取文件内容的函数有 ...

  6. ubuntu 忘记密码,忘记root密码的解决办法

    ubuntu的root默认是禁止使用的,在安装的时候也没有要求设置root的密码.要使用,给root设置密码就行了,sudo passwd root .如果只是普通用户密码忘了,用root就可以修改. ...

  7. ZOJ1608 Two Circles and a Rectangle

    Time Limit: 2 Seconds      Memory Limit: 65536 KB Give you two circles and a rectangle, your task is ...

  8. 2017-2018 ACM-ICPC, NEERC, Southern Subregional Contest I. Photo Processing

    题目链接 题意 将一个升序排好的数列切成若干段,要求每段的长度\(\gt k\),对每一段中最大值与最小值的差取个最大值,问这个最大值最小是多少. 思路 二分答案 怎么check呢? dp一下. d[ ...

  9. 解決eclipse 的alt + / 快捷鍵不好用

    最近公司电脑上的Eclipse没有了自动提示功能,也不是全部不提示,大多数情况下按下“alt+/”键还会产生提示,但是当我在java项目中邪main方法和syso的时候,“alt+/”则会失效,今天在 ...

  10. 语法错误: 标识符“__RPC__out_xcount_part” 解决方法

    1.错误描述 2.解决方案:将 $(DXSDK_DIR)\Include; 放到最后面,如下