加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 创业 > C语言 > 正文

mongo执行比较查询(字段之间的比较,当前前提是字段类型一致)

发布时间:2020-12-15 01:23:17 所属栏目:C语言 来源:网络整理
导读:准备mongo数据 db.test2.find().pretty(){ "_id" : ObjectId("55ed2ad8f74ae739786cc781"),"name" : "zhangsan","x" : 1,"y" : 3}{ "_id" : ObjectId("55ed2ad9f74ae739786cc782"),"name" : "lisi","x" : 3,"y" : 2}{ "_id" : ObjectId("55ed2ad9f74ae739786

准备mongo数据

 db.test2.find().pretty()
{
    "_id" : ObjectId("55ed2ad8f74ae739786cc781"),"name" : "zhangsan","x" : 1,"y" : 3
}
{
    "_id" : ObjectId("55ed2ad9f74ae739786cc782"),"name" : "lisi","x" : 3,"y" : 2
}
{
    "_id" : ObjectId("55ed2ad9f74ae739786cc783"),"name" : "wangwu","y" : 4
}
{
    "_id" : ObjectId("55ed2adaf74ae739786cc784"),"name" : "zhaoliu","x" : 4,"y" : 1
}
> db.test2.find({'$where': "this.x > this.y"},{'name': 1})
{ "_id" : ObjectId("55ed2ad9f74ae739786cc782"),"name" : "lisi" }
{ "_id" : ObjectId("55ed2adaf74ae739786cc784"),"name" : "zhaoliu" }

mongo比较查询

这样可以简单的实现比较查询。还有一种比较查询的方式就是使用聚合查询,如下:

 db.test2.aggregate([
...       {
...         $project : {
...            "_id": "$name",...            "val": { $subtract : [ "$x","$y" ] },...            "x": "$x",...            "y": "$y"
...         }
...       },...       {$match:{val: {$gt: 0}}},...       {$sort:{val: -1 }}
... ])
{ "_id" : "zhaoliu","y" : 1,"val" : 3 }
{ "_id" : "lisi","y" : 2,"val" : 1 }

还可以实现按比较之后的差值进行排序

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读