MongoDB 基础

基础

数据

存储数据方式:BSON

Collection 集合 > Key 键 > Value 值 > Document/Object (文档/对象)

数据类型

string integer boolean double null array object timestamp ObjectIDs InternationalizedStrings(UTF-8字符串)

数据库

连接

mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]

切换

use myinfo

备份(mongodump)

mongodump -h dbhost -d dbname -o dbdirectory

恢复(mongorerstore)

mongorestore -h dbhost -d dbname --�drop dbdirectory

监控

MongoDB中提供了mongostat 和 mongotop 两个命令来监控MongoDB的运行情况。

查询分析

常用函数有:

explain() //提供了查询信息,使用索引及查询统计等
hint()//强迫MongoDB使用一个指定的索引。

管理工具 Rockmongo

增删改查

集合操作

  • db.createCollection()
  • db.collection.drop()

数据库操作

  • db.dropDatabase()

数据操作

  • db.collection.insert()
  • db.collection.update(criteria, objNew, upsert, multi)
  • criteria : update的查询条件,类似sql update查询内where后面的。
  • objNew : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
  • upsert : 这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入
  • multi : mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多 条记录全部更新。
  • db.userdetails.remove( { "user_id" : "testuser" } )
  • db.userdetails.find(db.users.find({name: {$type: 2}});

条件操作符
$lt $gt $lte $gte $ne $type $inc $not

函数

  • limit(NUMBER) 限制数量
  • skip(NUMBER) 跳过数量
  • sort({key: 1/-1}) 排序
  • db.collection.aggregate(AGGREGATE_OPERATION) 聚合 相当于count(*)
  • $sum $avg $min $max $first $last $push $addToSet

索引

db.collection.ensureIndex({KEY:1/-1})

全文检索

db.adminCommand({setParameter:true,textSearchEnabled:true})
mongod --setParameter textSearchEnabled=true

  • 创建全文索引
    db.posts.ensureIndex({post_text:"text"})
  • 使用全文索引
    db.posts.find({$text:{$search:"w3cschool.cc"}})
  • 删除全文索引
  • 删除已存在的全文索引,可以使用 find 命令查找索引名:
    db.posts.getIndexes()
    db.posts.dropIndex("post_text_text") //本例的索引名为post_text_text

管道命令

  • $project:修改输入文档的结构。可以用来重命名、增加或删除域,也可以用于创建计算结果以及 嵌套文档。
  • $match:用于过滤数据,只输出符合条件的文档。$match使用MongoDB的标准查询操作。
  • $limit:用来限制MongoDB聚合管道返回的文档数。
  • $skip:在聚合管道中跳过指定数量的文档,并返回余下的文档。
  • $unwind:将文档中的某一个数组类型字段拆分成多条,每条包含数组中的一个值。
  • $group:将集合中的文档分组,可用于统计结果。
  • $sort:将输入文档排序后输出。
  • $geoNear:输出接近某一地理位置的有序文档。

原子操作

  • $set 用来指定一个键并更新键值,若键不存在并创建。{ $set : { field : value } }
  • $unset 用来删除一个键。{ $unset : { field : 1} }
  • $inc $inc可以对文档的某个值为数字型(只能为满足要求的数字)的键进行增减的操作。{ $inc : { field : value } }
  • $push 把value追加到field里面去,field一定要是数组类型才行,如果field不存在,会新增一个数组类型加进去。 { $push : { field : value } }
  • $pushAll 同$push,只是一次可以追加多个值到一个数组字段内。{ $pushAll : { field : value_array } }
  • $pull 从数组field内删除一个等于value值。{ $pull : { field : _value } }
  • $addToSet 增加一个值到数组内,而且只有当这个值不在数组内才增加。
  • $pop 删除数组的第一个或最后一个元素{ $pop : { field : 1 } }
  • $rename 修改字段名称{ $rename : { old_field_name : new_field_name } }
  • $bit 位操作,integer类型 {$bit : { field : {and : 5}}}

数据库引用

  • 1:1 (1对1)
  • 1: N (1对多)
  • N: 1 (多对1)
  • N: N (多对多)

DBRefs
{ $ref : , $id : , $db : }

  • $ref:集合名称
  • $id:引用的id
  • $db:数据库名称,可选参数
{ 
"_id":ObjectId("53402597d852426020000002"),
"address": {
"$ref": "address_home",
"$id": ObjectId("534009e4d852427820000002"),
"$db": "w3cschoolcc"},
"contact": "987654321",
"dob": "01-01-1991",
"name": "Tom Benzamin"
}
> var user = db.users.findOne({"name":"Tom Benzamin"})
> var dbRef = user.address
> db[dbRef.$ref].findOne({"_id":(dbRef.$id)})
{
"_id" : ObjectId("534009e4d852427820000002"),
"building" : "22 A, Indiana Apt",
"pincode" : 123456,
"city" : "Los Angeles",
"state" : "California"
}

参考

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,718评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,683评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,207评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,755评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,862评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,050评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,136评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,882评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,330评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,651评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,789评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,477评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,135评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,864评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,099评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,598评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,697评论 2 351

推荐阅读更多精彩内容

  • 1.NoSQL和MongoDB简介 文档是以二进制格JSON(BSON)对象的方式存储的,使用集合将数据编组,相当...
    JAVA觅音阁阅读 804评论 0 1
  • 关于operators 官方参考文档:https://docs.mongodb.org/manual/refere...
    我看不见阅读 2,504评论 0 3
  • 从2012年初开始,公司的一些核心产品准备开始陆续迁移到MongoDB上,我们尝试着从一个小产品开始使用,陆续将其...
    UncleYee阅读 1,957评论 0 3
  • 原文地址 首先,我们要了解MongoDB的基本运行机制。这将有助于我们理解MongoDB的核心。在此之前,我们需要...
    风雪围城阅读 356评论 0 2
  • 1.Runloop基础知识 (RunLoop可以理解为就是为多线程而存在的) 1.1 RunLoop基本概念:运行...
    牧马人_hlc阅读 826评论 4 17