微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

准备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 }

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐