简单的的增删改查数据
在查询结果中指定显示或者不显示某个字段
例如,我们希望在 lessons 集合中查找所有数据,但是不希望在返回结果中包含 slides 字段;因为 slides 是一个巨长的以 base64 表示的图片数组,影响查询结果的阅读。
那么我们就可以在 query object 后面跟上一个参数。如下:
复制代码 代码如下:
db.lessons.find({}, {slides:0});
同样也可以明确指定显示哪些字段:
复制代码 代码如下:
db.bios.find(
{ },
{ name: 1, contribs: 1, _id: 0 }
)
比较操作 – 大于和小于
我们要查询时间范围在 startTime 和 endTime 间的数据记录,同时要求 Content 内容是数字 1 到 5。
复制代码 代码如下:
db.wemessages.find( {$and: [
{ CreateTime: {$gt: (startTime.getTime()/1000).toString()} },
{ CreateTime: {$lt: (endTime.getTime()/1000).toString()} },
{ Content: {$in: ['1','2','3','4','5']} }
]}
);
这里我们使用了 $and 逻辑操作符,和 $gt, $lt, $in 比较操作符。
有关 MongoDB 的操作符,参见:http://docs.mongodb.org/manual/reference/operator/query/
更新一条记录的某些属性
使用 $set 表示只更新指定的字段,而不修改其他字段,我们一般情况下都会是这种意图。
复制代码 代码如下:
db.lessons.update({}, {$set:{'course_id':'c.101'}});
更新多条记录
使用 {multi: true}
复制代码 代码如下:
db.lessons.update({}, {$set:{'course_id':'c.101'}}, {multi: true});
db.muusers.update({username: 'tom'}, {$set: {mobile: '6508639713'}}, {multi: true});
排序查询结果
使用 sort 方法
复制代码 代码如下:
db.muusers.find().sort({firsttime: -1});
-1 降序,1 升序
清爽地查看查询结果
使用 pretty 方法
复制代码 代码如下:
db.lessons.find({lesson: 1}, {slides: 0, mp3voice:0, wavvoice:0, wavvoicemin: 0}).pretty();
查看不存在某个字段的记录
使用 $exists
复制代码 代码如下:
db.questions.find({'sequence_id': 1, 'pngslide': {$exists: false}});
db.mycollection.find( { "price" : { "$exists" : false } } )
限定查询结果个数 limit, 以及跳过开始的多少条记录 skip
使用 limit 和 skip
复制代码 代码如下:
db.translation_memory.find({mp3voice: {$exists: false}}, null, {limit: 100});
删除 collection 中的所有内容
使用 collection 的 remove 方法
复制代码 代码如下:
db.collection.remove();
得到 collection 中一个字段的长度
链式调用
复制代码 代码如下:
db.lessons.find({lesson: 1}).toArray()[0].slides.join('').length
Collection 操作
更名 collection
使用 renameCollection 方法
复制代码 代码如下:
db.quizzes.renameCollection('questions');
删除一个字段
使用 $unset
复制代码 代码如下:
db.questions.update({}, {$unset: {quiz_name:1}}, {multi: true});
db.learning_progress.update({}, {$unset: {lesson:1}}, {multi: true});
db.lessons.update({}, {$unset: {wavvoice:1, wavvoicemin:1}}, {multi: true});
修改一个字段的名称
使用 $rename
复制代码 代码如下:
db.students.update( { _id: 1 }, { $rename: { 'nickname': 'alias', 'cell': 'mobile' } } )
注意:有些MongoDB的关键词不能用做Collection的名称,例如:group。
以上所述就是本文的全部内容了,希望大家能够喜欢。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 黄乙玲1988-无稳定的爱心肝乱糟糟[日本东芝1M版][WAV+CUE]
- 群星《我们的歌第六季 第3期》[320K/MP3][70.68MB]
- 群星《我们的歌第六季 第3期》[FLAC/分轨][369.48MB]
- 群星《燃!沙排少女 影视原声带》[320K/MP3][175.61MB]
- 乱斗海盗瞎6胜卡组推荐一览 深暗领域乱斗海盗瞎卡组分享
- 炉石传说乱斗6胜卡组分享一览 深暗领域乱斗6胜卡组代码推荐
- 炉石传说乱斗本周卡组合集 乱斗模式卡组最新推荐
- 佟妍.2015-七窍玲珑心【万马旦】【WAV+CUE】
- 叶振棠陈晓慧.1986-龙的心·俘虏你(2006复黑限量版)【永恒】【WAV+CUE】
- 陈慧琳.1998-爱我不爱(国)【福茂】【WAV+CUE】
- 咪咕快游豪礼放送,百元京东卡、海量欢乐豆就在咪咕咪粉节!
- 双11百吋大屏焕新“热”,海信AI画质电视成最大赢家
- 海信电视E8N Ultra:真正的百吋,不止是大!
- 曾庆瑜1990-曾庆瑜历年精选[派森][WAV+CUE]
- 叶玉卿1999-深情之选[飞图][WAV+CUE]