第七章 使用MongoDB shell执行其他数据查找操作

MongoDB 高级集合数据查找

题纲:

  • 确定与查找操作匹配的文档数;
  • 以特定的顺序返回文档;
  • 限制返回的文档数;
  • 大型数据集分页;
  • 减少返回的文档包含的字段;
  • 查找数据集中特定字段的不同值;

计算文档数:

count() 可以实现,如下:

cursor = db.wordscoll.finc({first:{$in:['a','b','c']}});
itemCount = cursor.count();

练习

对结果进行排序:

Cursor对象的方法sort()让您能够指定要根据哪些字段对游标中的文档进行排序,并按相应的顺序返回文档。方法sort()将一个对象作为参数,这个对象字段名用作属性名, 并使用值1(升序)-1(降序)来指定排序顺序。如:

 myCollection.find().sort({name:1}).sort({value:-1});

对同一个游标,可以多次使用sort(),从而依次按不周的字段进行排序。如上述代码的例子。

限制结果集:

  • 只接受一定数量的文档;
  • 限制返回的字段;
  • 对结果分页,批量的获取它们;

只接受一定数量的文档 : 可以采用limit() 来指定返回文档的数量;
注: myCollection.find().limit(0);,表示不限制

限制返回的字段

实现此功能, 是需要启用find()操作作的的projection参数。参数是一个文档, 属性值为0/false表示不包含, 1/true 表示包含。如:
返回first字段为t的文档时, 要排除字段status、value和comments,可使用下面的projection参数:

 find({first:"t"},{status:false,value:false,comments:false});

再如:只想返回word,size 二个字段:

find({first:"t"},{word:1,size:1})

结果集分页

采用limit()、skip()进行处理;
如:

cursor = mycol.find().sort({name:1});
cursor.limit(10);
cursor.skip(0);
cursor = mycol.find().sort({name:1});
cursor.limit(10);
cursor.skip(10);
cursor = mycol.find().sort({name:1});
cursor.limit(10);
cursor.skip(20);

以上skip(),方法相当于pagenumber 对应的是几页, 但这里不是指页码,而是对应页数的第n-1条记录。

查找不同的字段

Collection对象的方法distinct()方法能让指定字段的不同值列表,这种方法的语法如下:
distinct(key, [query]);
说明:
参数key 是一个字符串,指定了要获取哪个字段的不同值, 要获取子文档中字段的不同值,可使用句点语法,如status.count。
参数query 是一个包含标准查询选项目的对象,指定了要从哪些文档中获取不同的字段值。
例如:有一个包含字段first、last和age的用户文档,要获取年龄超过65岁的用户的不同姓名, 可使用如下操作,这里面需要排除重复的姓名, 显示所有不同的姓名, 所以这里采用了distinct这个关键字作为方法名

lastnames = myUsers.distinct('last',{age:{$gt:65}});

方法distinct()返回,指定条件下, 指定字段不重复的记录集合。

lastnames = myUsers.distinct('last',{age:{$gt:70}});
















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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,580评论 18 139
  • 原文:https://my.oschina.net/liuyuantao/blog/751438 查询集API 参...
    阳光小镇少爷阅读 3,809评论 0 8
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,560评论 18 399
  • 对于龚晓明医生的《我的中医观》,总结下来就是一个问答:你愿意吃屎么?有人愿意。 通常来说,所谓的神枪手,就是那些能...
    爽临简书阅读 1,622评论 3 1
  • 端模式分为小端字节序与大端字节序。 1. 小端字节序(Little Endian, LE)低字节存于内存低地址,高...
    Josaber阅读 230评论 0 1