设为首页 收藏本站
查看: 941|回复: 0

[经验分享] mongodb查询(原创)

[复制链接]

尚未签到

发表于 2015-7-6 11:32:49 | 显示全部楼层 |阅读模式
  1.1查询返回指定的键:
  --先查询全部的键如下:
  > db.person.find()
{ "_id" : ObjectId("4f508eeff536645151bca18c"), "age" : 1 }
{ "_id" : ObjectId("4f508e7bf536645151bca18a"), "name" : "tangke", "age" : 21 }。
  --再查询返回指定的键如下:
  > db.person.find({},{"age":1})
{ "_id" : ObjectId("4f508eeff536645151bca18c"), "age" : 1 }
{ "_id" : ObjectId("4f508e7bf536645151bca18a"), "age" : 21 }。
  以上需要解释的是:第一个参数是要指定查询的范围,第二个参数是要找到的键并按升序进行排列。
  --还有一个小技巧:你如果不想返回这个_id,你可以这样做:
  > db.person.find({},{"age":1,"_id":0})
{ "age" : 1 }
{ "age" : 21 }。
  1.2mongodb中的查询符号:
  $lt,$lte,$gt,$gte,$ne:这几个符号的意思不用解释了吧,用过html语言的人都知道。
  另外还有$in,$nin,$or也不解释,你懂的。
  1.3用正则表达式匹配查询条件:(这个我很喜欢,因为我学过perl,里面的正则表达式,很漂亮)
  --没有使用正则式的查询
  > db.person.find()
{ "_id" : ObjectId("4f508eeff536645151bca18c"), "age" : 1 }
{ "_id" : ObjectId("4f508e7bf536645151bca18a"), "name" : "tangke", "age" : 21 }
  --使用正则表达式查出以name以t开头的文档并且不分大小写:
  > db.person.find({"name":/^t*/i})
{ "_id" : ObjectId("4f508e7bf536645151bca18a"), "name" : "tangke", "age" : 21 }
---注:/^t/i,   表示以t字母开头,并且不分大小写的字符串。
  1.4查询数组:
  $all的用法:
  现在数据库中有如下的数据:
  > db.fruit.find()
{ "_id" : ObjectId("4f546dadcf486e7efbd41fcc"), "fruit" : [ "apple", "banana", "
orange" ] }
{ "_id" : ObjectId("4f546dd1cf486e7efbd41fcd"), "fruit" : [ "apple", "peach", "b
anana" ] };
  --现在用$all进行查询,查出同时包括apple,peach的文档。
  > db.fruit.find({"fruit":{"$all":["apple","peach"]}})
{ "_id" : ObjectId("4f546dd1cf486e7efbd41fcd"), "fruit" : [ "apple", "peach", "b
anana" ] };
  $size: 用来查询符合长度符合的数组。
  $slice:返回多少条键的记录;
DSC0000.jpg
  $slice也可以用来查询指定偏移量的数据:
DSC0001.png
  --上面的语句表达的意思是跳过前二十三条数据,然后查询十条数据。
  


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-83793-1-1.html 上篇帖子: MongoDB新版本特性 下篇帖子: MongoDB的自定义序列化(Customizing serialization)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表