MongoDB 基础

作者: KeKeMars | 来源:发表于2015-11-06 12:34 被阅读255次

基础

数据

存储数据方式: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"
}

参考

相关文章

网友评论

    本文标题:MongoDB 基础

    本文链接:https://www.haomeiwen.com/subject/yfjchttx.html