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 }

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

相关文章

显卡天梯图2024最新版,显卡是电脑进行图形处理的重要设备,...
初始化电脑时出现问题怎么办,可以使用win系统的安装介质,连...
todesk远程开机怎么设置,两台电脑要在同一局域网内,然后需...
油猴谷歌插件怎么安装,可以通过谷歌应用商店进行安装,需要...
虚拟内存这个名词想必很多人都听说过,我们在使用电脑的时候...