[整理]MongoDB 常用命令总结

MongoDB 常用命令总结

简单的的增删改查数据

在查询结果中指定显示或者不显示某个字段


例如,我们希望在 lessons 集合中查找所有数据,但是不希望在返回结果中包含 slides 字段;因为 slides 是一个巨长的以 base64 表示的图片数组,影响查询结果的阅读。

那么我们就可以在 query object 后面跟上一个参数。如下:
[sql]  view plain copy
  1. db.lessons.find({}, {slides:0});  

同样也可以明确指定显示哪些字段:

[sql]  view plain copy
  1. db.bios.find(  
  2.   
  3. { },  
  4.   
  5. name: 1, contribs: 1, _id: 0 }  
  6.   
  7. )  

比较操作 – 大于和小于

我们要查询时间范围在 startTime 和 endTime 间的数据记录,同时要求 Content 内容是数字 1 到 5。

[sql]  view plain copy
  1. db.wemessages.find( {$and: [  
  2.   
  3.     { CreateTime: {$gt: (startTime.getTime()/1000).toString()} },  
  4.   
  5.     { CreateTime: {$lt: (endTime.getTime()/1000).toString()} },  
  6.   
  7.     { Content: {$in: ['1','2','3','4','5']} }  
  8.   
  9.   ]}  
  10.   
  11. );  

这里我们使用了 $and 逻辑操作符,和 $gt, $lt, $in 比较操作符。

有关 MongoDB 的操作符,参见: http://docs.mongodb.org/manual/reference/operator/query/

更新一条记录的某些属性

使用 $set 表示只更新指定的字段,而不修改其他字段,我们一般情况下都会是这种意图。

[sql]  view plain copy
  1. db.lessons.update({}, {$set:{'course_id':'c.101'}});  

更新多条记录

使用 {multi: true},参见:  http://www.lai18.com/content/411017.html 

[sql]  view plain copy
  1. db.lessons.update({}, {$set:{'course_id':'c.101'}}, {multi: true});  
  2.   
  3. db.muusers.update({username: 'tom'}, {$set: {mobile: '6508639713'}}, {multi: true});  

排序查询结果

使用 sort 方法

[sql]  view plain copy
  1. db.muusers.find().sort({firsttime: -1});  

-1 降序,1 升序

清爽地查看查询结果

使用 pretty 方法

[sql]  view plain copy
  1. db.lessons.find({lesson: 1}, {slides: 0, mp3voice:0, wavvoice:0, wavvoicemin: 0}).pretty();  

查看不存在某个字段的记录

使用 $exists

[sql]  view plain copy
  1. db.questions.find({'sequence_id': 1, 'pngslide': {$exists: false}});  
  2.   
  3. db.mycollection.find( { "price" : { "$exists" : false } } )  

限定查询结果个数 limit, 以及跳过开始的多少条记录 skip

使用 limit 和 skip

[sql]  view plain copy
  1. db.translation_memory.find({mp3voice: {$exists: false}}, null, {limit: 100});  

删除 collection 中的所有内容

使用 collection 的 remove 方法

[sql]  view plain copy
  1. db.collection.remove();  

得到 collection 中一个字段的长度

链式调用

[sql]  view plain copy
  1. db.lessons.find({lesson: 1}).toArray()[0].slides.join('').length  

Collection 操作

更名 collection


使用 renameCollection 方法

[sql]  view plain copy
  1. db.quizzes.renameCollection('questions');  

删除一个字段

使用 $unset

[sql]  view plain copy
  1. db.questions.update({}, {$unset: {quiz_name:1}}, {multi: true});  
  2.   
  3. db.learning_progress.update({}, {$unset: {lesson:1}}, {multi: true});  
  4.   
  5. db.lessons.update({}, {$unset: {wavvoice:1, wavvoicemin:1}}, {multi: true});  

修改一个字段的名称

使用 $rename

[sql]  view plain copy
  1. db.students.update( { _id: 1 }, { $rename: { 'nickname''alias''cell''mobile' } } )  

注意:有些MongoDB的关键词不能用做Collection的名称,例如:group。

 

《MongoDB技术知识》系列技术文章整理收藏 

1mongoDB入门需要了解的基本知识

2MongoDB入门教程(包含安装、常用命令、相关概念、使用技巧、常见操作等)

3MongoDB入门教程之分片技术详解

4MongoDB入门教程之常用的运维技术介绍

5MongoDB入门教程之C#驱动操作实例

6MongoDB入门教程之主从复制配置详解

7MongoDB入门教程之聚合和游标操作介绍

8MongoDB入门教程之细说MongoDB数据库的增删查改操作

9MongoDB入门教程之索引操作浅析

10MongoDB入门教程之Windows下的MongoDB数据库安装图解

11MongoDB查询字段没有创建索引导致的连接超时异常解案例分享

12MongoDB日志文件过大的解决方法

13MongoDB社区版和企业版的差别对照表

14MongoDB中文社区发起人带你学习mongoDB

15对MongoDB数据库性能瓶颈分析

16MongoDB 分页查询的方法及性能

17MongoDB分片存储的集群架构实现

18Mongodb批量删除gridfs文件实例

19Mongodb增加、移除Shard Server实例

20Mongodb增加、移除Arbiter节点实例

21CentOS系统下MongoDB安装及配置教程

22MongoDB修改、删除文档的域属性实例

23Python中的MongoDB基本操作:连接、查询实例

24MongoDB导出查询结果到文件例子

25MongoDB中创建索引需要注意的事项

26MongoDB中的一些坑(最好不要用)

27给MongoDB添加用户权限方法分享

28Linux系统下MongoDB的简单安装与基本操作

29MongoDB教程之基本管理命令

30MongoDB教程之聚合(count、distinct和group)

31MongoDB教程之索引介绍

32MongoDB教程之数据操作实例

33MongoDB教程之入门基础知识

34MongoDB教程之查询操作实例

35MongoDB系列教程(四):设置用户访问权限

36MongoDB系列教程(八):GridFS存储详解

37MongoDB数据库的特色和优点介绍

38MongoDB简介 MongoDB五大特色

39MongoDB系列教程(六):java操作mongodb实例

40MongoDB系列教程(七):MongoDb数据结构详解

41MongoDB系列教程(五):mongo语法和mysql语法对比学习

42MongoDB系列教程(二):MongoDB简介

43MongoDB系列教程(一):NoSQL起源

44MongoDB中的MapReduce简介

45MongoDB系列教程(三):Windows中下载和安装MongoDB

46浅谈MongoDB的备份方式

47MongoDB 常用命令总结

48MongoDB与MySQL的操作对比表及区别介绍

49MongoDB安全配置详解

50MongoDB中的bson介绍和使用实例

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值