17

假设我有一个集合,其中包含具有浮点数的 ratio 属性的文档。

{'ratio':1.437}

如何编写查询以查找具有最接近给定整数的值的单个文档,而不使用驱动程序将它们全部加载到内存中并找到具有最小值的文档abs(x-ratio)

4

2 回答 2

30

有趣的问题。我不知道您是否可以在一个查询中完成,但您可以在两个查询中完成:

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 更新

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}
])
于 2012-11-07T18:25:25.157 回答
7

我有另一个想法,但非常棘手,需要更改您的数据结构。

您可以使用mongodb 支持的地理位置索引

首先,将您的数据更改为此结构,并将第二个值保留为 0

{'ratio':[1.437, 0]}

然后您可以使用$near运算符找到最接近的比率值,并且由于运算符返回一个按距离排序的列表以及您给出的整数,因此您必须使用limit仅获取最接近的值。

db.places.find( { ratio : { $near : [50,0] } } ).limit(1)

如果您不想这样做,我认为您可以使用@JohnnyHK 的答案 :)

于 2012-11-07T19:42:58.633 回答