假设我有一个集合,其中的文档具有一个浮点数的ratio属性.
{'ratio':1.437}
如何编写一个查询来查找与给定整数最接近的单个文档,而不使用驱动程序将它们全部加载到内存中,并查找最小值为abs(x-ratio)
的文档?
假设我有一个集合,其中的文档具有一个浮点数的ratio属性.
{'ratio':1.437}
如何编写一个查询来查找与给定整数最接近的单个文档,而不使用驱动程序将它们全部加载到内存中,并查找最小值为abs(x-ratio)
的文档?
有趣的问题.我不知道你是否可以在一个查询中完成,但你可以在两个查询中完成:
var x = 1; // given integer
closestBelow = db.test.find({ratio: {$lte: x}}).sort({ratio: -1}).limit(1);
closestAbove = db.test.find({ratio: {$gt: x}}).sort({ratio: 1}).limit(1);
然后,只需判断两个文档中哪个文档的ratio
最接近目标整数.
MongoDB 3.2 Update
3.2版本增加了对$abs
绝对值聚合运算符的支持,现在可以在单个aggregate
查询中完成这一操作:
var x = 1;
db.test.aggregate([
// Project a diff field that's the absolute difference along with the original doc.
{$project: {diff: {$abs: {$subtract: [x, '$ratio']}}, doc: '$$ROOT'}},
// Order the docs by diff
{$sort: {diff: 1}},
// Take the first one
{$limit: 1}
])