美文网首页mongodb学习MongoDB
MongoDB 基础操作(二)

MongoDB 基础操作(二)

作者: 无赖宵小 | 来源:发表于2018-11-22 10:28 被阅读0次

MongoDB 索引

  • 对某个键按照升续或降续创建索引;
  • 查询时首先根据查询条件查找到对应的索引条目,然后找对索引条目对应的文档指针(文档在磁盘上的存储位置),根据文档指针再去磁盘中找到相应的文档;
  • 整个过程不需要扫描全表,速度比较快。
  • db.集合名.ensureIndex({KEY: NUMBER}) 对数据添加索引
ensureIndex() 必选参数说明:
  • KEY:要创建的索引字段
  • NUMBER:使用 1 和 -1 指定索引排序的方式,其中 1 为升序排列,-1 位降序排列。
ensureIndex() 可选参数说明:
Parameter Type Description
background Boolean 建索引过程会阻塞其它数据库操作,background 可指定以后台方式创建索引,即增加 "background" 可选参数。"background" 默认值为 false
unique Boolean 建立的索引是否唯一。指定为 true 创建唯一索引。默认值为 false
name string 索引的名称。如果未指定,MongoDB 的通过连接索引的字段名和排序顺序生成一个索引名称。
dropDups Boolean 在建立唯一索引时是否删除重复记录,指定 true 创建唯一索引。默认值为 false
sparse Boolean 对文档中不存在的字段数据不启用索引;这个参数需要特别注意,如果设置为 true 的话,在索引字段中不会查询出不包含对应字段的文档,默认值为 false
expireAfterSeconds integer 指定一个以秒为单位的数值,完成 TTL 设定,设定集合的生存时间。
v index version 索引的版本号。默认的索引版本取决于 mongod 创建索引时运行的版本。
weights document 索引权重值,数值在 1 到 99,999 之间,表示该索引相对于其他索引字段的得分权重。
default_language string 对于文本索引,该参数决定了停用词及词干和词器的规则的列表,默认为英语。
language_override string 对于文本索引,该参数指定了包含在文档中的字段名,语言覆盖默认的language,默认值为 language

MongoDB 聚合

  • 聚合操作主要用于对数据的批量处理,往往将记录按条件分组以后,然后再进行一系列操作,例如,求最大值、最小值、平均值,求和等操作。

  • 聚合操作还能够对记录进行复杂的操作,主要用于数理统计和数据挖掘。

  • db.集合名.aggregate(AGGREGATE_OPERATION) 聚合

例:
db.test.aggregate([{$group: {_id: "$status", num: {$sum: 1}}}])
聚合求和
聚合表达式
表达式 描述 实例
$sum 计算总和。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$sum : "$likes"}}}])
$avg 计算平均值 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$avg : "$likes"}}}])
$min 获取集合中所有文档对应值得最小值。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$min : "$likes"}}}])
$max 获取集合中所有文档对应值得最大值。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$max : "$likes"}}}])
$push 在结果文档中插入值到一个数组中。 db.mycol.aggregate([{$group : {_id : "$by_user", url : {$push: "$url"}}}])
$addToSet 在结果文档中插入值到一个数组中,但不创建副本。 db.mycol.aggregate([{$group : {_id : "$by_user", url : {$addToSet : "$url"}}}])
$first 根据资源文档的排序获取第一个文档数据。 db.mycol.aggregate([{$group : {_id : "$by_user", first_url : {$first : "$url"}}}])
$last 根据资源文档的排序获取最后一个文档数据 db.mycol.aggregate([{$group : {_id : "$by_user", last_url : {$last : "$url"}}}])
聚合管道、聚合框架的常用操作
操作 描述 实例
$project 修改输入文档的结构。可以用来重命名、增加或删除域,也可以用于创建计算结果以及嵌套文档。 db.article.aggregate({$project : {_id : 0 ,title : 1 ,author: 1 ,}} );
$match 用于过滤数据,只输出符合条件的文档。$match使用MongoDB的标准查询操作。 db.articles.aggregate( [{ $match : { score : { $gt : 70, $lte : 90 } } },{ $group: { _id: null, count: { $sum: 1 } } }] );
$limit 用来限制MongoDB聚合管道返回的文档数。
$skip 在聚合管道中跳过指定数量的文档,并返回余下的文档。 db.article.aggregate({ $skip : 5 });
$unwind 将文档中的某一个数组类型字段拆分成多条,每条包含数组中的一个值。
$group 将集合中的文档分组,可用于统计结果。
$sort 将输入文档排序后输出。
$geoNear 输出接近某一地理位置的有序文档。

MongoDB 备份与恢复

MongoDB数据备份

mongodump - h dbhost -d dbname -o dbdirectory
  • -h
    MongoDB所在服务器地址,需要指定端口号,例如默认地址:127.0.0.1:27017
  • -d
    需要备份的数据库实例,例如:test
  • -o
    备份的数据存放位置,该目录需要提前建立,例如:d:\data\dump,当备份完成后,系统自动在 dump 目录下建立一个 test 目录,在这个目录里面存放该数据库实例的备份数据。
  • mongodump 命令可选参数列表
语法 描述 实例
mongodump --host HOST_NAME --port PORT_NUMBER 该命令将备份所有MongoDB数据 mongodump --host 127.0.0.1 --port 27017
mongodump --dbpath DB_PATH --out BACKUP_DIRECTORY mongodump --dbpath /data/db/ --out /data/backup/
mongodump --collection COLLECTION --db DB_NAME 该命令将备份指定数据库的集合。 mongodump --collection mycol --db test

MongoDB 数据恢复

>mongorestore -h dbhost -d dbname --directoryperdb dbdirectory
  • -h
    MongoDB所在服务器地址
  • -d
    需要恢复的数据库实例,例如:test,当然这个名称也可以和备份时候的不一样,比如 test2。
  • --directoryperdb
    备份数据所在的位置,例如:d:\data\dump\test,注意不是备份时的 d:\data\dump。
  • --drop
    恢复的时候,先删除当前数据,然后恢复备份的数据。就是说,恢复后,备份后添加修改的数据都会被删除,需要慎用!!!

参考文档一: MongoDB 文档
参考文档二: MongoDB W3C文档

相关文章

网友评论

    本文标题:MongoDB 基础操作(二)

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