专栏首页运维经验分享mongodb的查询语句学习摘要 原

mongodb的查询语句学习摘要 原

看了些资料,对应只需要知道怎么查询和使用mongodb的我来说,这些足够啦。

左边是mongodb查询语句,右边是sql语句。对照着用,挺方便。

db.users.find() select * from users

db.users.find({"age" : 27}) select * from users where age = 27

db.users.find({"username" : "joe", "age" : 27}) select * from users where "username" = "joe" and age = 27

db.users.find({}, {"username" : 1, "email" : 1}) select username, email from users

db.users.find({}, {"username" : 1, "_id" : 0}) // no case  // 即时加上了列筛选,_id也会返回;必须显式的阻止_id返回

db.users.find({"age" : {"$gte" : 18, "$lte" : 30}}) select * from users where age >=18 and age <= 30 // $lt(<) $lte(<=) $gt(>) $gte(>=)

db.users.find({"username" : {"$ne" : "joe"}}) select * from users where username <> "joe"

db.users.find({"ticket_no" : {"$in" : [725, 542, 390]}}) select * from users where ticket_no in (725, 542, 390)

db.users.find({"ticket_no" : {"$nin" : [725, 542, 390]}}) select * from users where ticket_no not in (725, 542, 390)

db.users.find({"$or" : [{"ticket_no" : 725}, {"winner" : true}]}) select * form users where ticket_no = 725 or winner = true

db.users.find({"id_num" : {"$mod" : [5, 1]}}) select * from users where (id_num mod 5) = 1

db.users.find({"$not": {"age" : 27}}) select * from users where not (age = 27)

db.users.find({"username" : {"$in" : [null], "$exists" : true}}) select * from users where username is null // 如果直接通过find({"username" : null})进行查询,那么连带"没有username"的纪录一并筛选出来

db.users.find({"name" : /joey?/i}) // 正则查询,value是符合PCRE的表达式

db.food.find({fruit : {$all : ["apple", "banana"]}}) // 对数组的查询, 字段fruit中,既包含"apple",又包含"banana"的纪录

db.food.find({"fruit.2" : "peach"}) // 对数组的查询, 字段fruit中,第3个(从0开始)元素是peach的纪录

db.food.find({"fruit" : {"$size" : 3}}) // 对数组的查询, 查询数组元素个数是3的记录,$size前面无法和其他的操作符复合使用

db.users.findOne(criteria, {"comments" : {"$slice" : 10}}) // 对数组的查询,只返回数组comments中的前十条,还可以{"$slice" : -10}, {"$slice" : [23, 10]}; 分别返回最后10条,和中间10条

db.people.find({"name.first" : "Joe", "name.last" : "Schmoe"})  // 嵌套查询

db.blog.find({"comments" : {"$elemMatch" : {"author" : "joe", "score" : {"$gte" : 5}}}}) // 嵌套查询,仅当嵌套的元素是数组时使用,

db.foo.find({"$where" : "this.x + this.y == 10"}) // 复杂的查询,$where当然是非常方便的,但效率低下。对于复杂查询,考虑的顺序应当是 正则 -> MapReduce -> $where

db.foo.find({"$where" : "function() { return this.x + this.y == 10; }"}) // $where可以支持javascript函数作为查询条件

db.foo.find().sort({"x" : 1}).limit(1).skip(10); // 返回第(10, 11]条,按"x"进行排序; 三个limit的顺序是任意的,应该尽量避免skip中使用large-number

(adsbygoogle = window.adsbygoogle || []).push({});

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • mongodb count查询记录条数 原

    使用count()方法查询表中的记录条数,例如,下面的命令查询表users的记录数量:

    拓荒者
  • linux下查看磁盘分区的文件系统格式 原

    Filesystem Type 1K-blocks Used Available Use% Mounted on /dev/sda1 ext4 2064242...

    拓荒者
  • 日志-nginx的access_log与error_log

    3."GET /data/upload/shop/common/loading.gif HTTP/1.0"  :

    拓荒者
  • [PHP] 超全局变量$_FILES上传文件

    通过 HTTP POST 方式上传到当前脚本的项目的数组,PHP 能够接受任何来自符合 RFC-1867 标准的浏览器上传的文件,

    陶士涵
  • mongodb查询的语法总结

    $size是匹配数组内的元素数量的,如有一个对象:{a:[“foo”]},他只有一个元素:

    周小董
  • H3CNE实验系列 | 缺省路由和静态路由

    使各网络间能互相通信,R1 和 R3 使用缺省路由,指向 R2;在 R2 上配置静态路

    网络技术联盟站
  • 重温:凡客倒下陈年万字忏悔书,创业者不要高兴太早!

    大数据文摘
  • 凡客倒下陈年万字忏悔书,创业者不要高兴太早!

    用户1756920
  • 凡客做小米忠实学徒能否逆转颓势?

    《中国好声音》正在热播,去年这个时节凡客曾向这个节目狂砸1000万,不过今年却难觅凡客踪影,这只是凡客变化的一个点。距离“搬家事件”一年的凡客已不再急行军,慢...

    罗超频道
  • Django项目快速搭建

    在开发阶段,为了能够快速预览到开发的效果,django提供了一个纯python编写的轻量级web服务器,仅在开发阶段使用。

    py3study

扫码关注云+社区

领取腾讯云代金券