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 4557 非诚勿扰(Treap找后继)

    非诚勿扰 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) Total Submi ...

  2. POJ 3648 Wedding(2-SAT的模型运用+DFS | Tarjan)

    Wedding Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10427   Accepted: 3170   Specia ...

  3. cf 843 D Dynamic Shortest Path [最短路+bfs]

    题面: 传送门 思路: 真·动态最短路 但是因为每次只加1 所以可以每一次修改操作的时候使用距离分层的bfs,在O(n)的时间内解决修改 这里要用到一个小技巧: 把每条边(u,v)的边权表示为dis[ ...

  4. IPFS

    http://www.r9it.com/20190412/ipfs-private-net.html IPFS指令集中文版(一) https://www.jianshu.com/p/ce74b32d2 ...

  5. python数据结构之字典

    1.python字典的定义 1.用大括号{},以逗号分隔每个键值对,键与值之间用冒号连接 2.键:需要不可变的数据结构,值可以是任意的数据对象 3.字典是无序的,键在字典中必须是唯一,在字典中取值的方 ...

  6. 读扇区错误:0柱面0磁头1扇区(硬盘问题,蓝屏等 0x0000007B)

    原文发布时间为:2010-05-25 -- 来源于本人的百度文章 [由搬家工具导入] 读扇区错误:0柱面0磁头1扇区(硬盘问题,蓝屏等 0x0000007B) DISKGEN能找到,那就没什么大问题的 ...

  7. 让Dropdownlist既有静态项又有动态项或者既能有编辑项又能绑定数据源

    原文发布时间为:2008-10-27 -- 来源于本人的百度文章 [由搬家工具导入] protected void Page_Load(object sender, EventArgs e) //Dr ...

  8. Docker(三):Docker的基本概念

    Docker镜像: Docker镜像就是一个只读模板,例如,一个镜像可以包含Ubuntu操作系统环境,里面安装了Apache或用户需要的其它应用程序. 镜像可以用来创建Docker容器.Docker提 ...

  9. python print的参数介绍

    参考print的官方文档 print(...) print(value, ..., sep=' ', end='\n', file=sys.stdout, flush=False) Prints th ...

  10. hdu3452 无向树去掉最小的边集使任何叶子与根不连通 / 最小割

    思路一下就上来了,叶子向汇点连边,inf保证不会成为割,跑根到汇点最小割即可.注意无向树双向建边.基础题,分分钟1A: #include<iostream> #include<que ...