- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
学云签约讲师 王泽Mongodb开发视频教程—第八讲 Mongodb查询操作(下)
学云 为您提供高品质课件、学习督导服务、即时答疑、知识交易平台上节回顾find和findOne函数介绍查询条件使用方法特定类型的查询
学云 为您提供高品质课件、学习督导服务、即时答疑、知识交易平台本节目标$where子句的使用游标的使用方法
$where子句的使用学云 为您提供高品质课件、学习督导服务、即时答疑、知识交易平台$where,可以执行任意JavaScript作为查询的一部分!最典型的应用:一个文档,如果有两个键的值相等,就选出来,否则不选。 使用$where其实就是写了一个javascript函数,MongoDB在查询时,会将每个文档转换成一个javascript对象,然后扔到这个函数中去执行,通过返回结果来判断其是否匹配!在实际使用中,尽量避免使用”$where 条件操作符,因为其性能很差!在执行过程中,需要把每个档案转化为javascript对象!
$where子句的使用学云 为您提供高品质课件、学习督导服务、即时答疑、知识交易平台如果不可避免,则尽量这样写:find({”other“:”......“,......,“$where”:}),即将$where放最后,作为结果调优,让常规查询作为前置过滤条件!这样能减少一些性能损失!{_id:id,age:25,books:[js,c++],c:90,country:AUS,school:[{school:k,score:A},{school:k1,score:A1}],size:5}查询年龄大于22,喜欢看c++,在k学校上学的学生
$where子句的使用学云 为您提供高品质课件、学习督导服务、即时答疑、知识交易平台比较document里边两个key的值。举个例子,我们有个list,我们想返回里边的key的值里有相等的document。 db.foo.insert({apple : 1, banana : 6, peach : 3}) db.foo.insert({apple : 8, spinach : 4, watermelon : 4})第二个document里,菠菜和西瓜的值是相等的,这个应该返回,这个使用$条件查询符号是做不到的。
游标的使用方法学云 为您提供高品质课件、学习督导服务、即时答疑、知识交易平台MongoDB中find()函数返回一个游标,客户端通过对游标进行一些设置就能对查询结果进行有效地控制,如可以限制查询得到的结果数量、跳过部分结果、或对结果集按任意键进行排序等!我们之前在Shell中进行操作,都是直接使用find()函数,并没有使用其返回值,
游标的使用方法学云 为您提供高品质课件、学习督导服务、即时答疑、知识交易平台我们先通过javascript脚本向集合中填充100条文档,然后直接调用find函数。其会自动递归find返回的游标,将前20条数据展示在shell中。如果我们通过变量保留find函数的返回值,其不会自动进行遍历显示操作。var cursor = db.coll.find();
游标的使用方法学云 为您提供高品质课件、学习督导服务、即时答疑、知识交易平台调用完find后,此时Shell并不会去真正地访问数据库,而是等待开始要求获得结果的时候才向数据库发送查询请求!我们此时可以对这个游标进行各种设置,然后调用游标的hashNext()或next()方法,这样就会真正访问数据库,这是一个懒加载的过程。如下var cursor = db.coll.find(); while(cursor.hasNext()){ ... var doc = cursor.next(); ... // do stuff with doc ... };
游标的使用方法学云 为您提供高品质课件、学习督导服务、即时答疑、知识交易平台cursor.hasNext() cursor.next();上述代码中,当调用cursor.hasNext()时,查询被发往数据库,默认会返回前100条文档或者前4M的数据(两者之中较小的),这样下次next或hasNext都是本地调用了!当这组数据被遍历完毕,hasNext会导致再次去访问数据库,直到所有结果被返回
limit、skip、sort使用学云
文档评论(0)