在我的 MongoDB 数据库中,我有一系列产品。每个产品都包含一个数组中的发布信息,例如
{
"name" : "foo",
"release" : [{
"region" : "GB",
"active" : "Y",
"date" : ISODate("2012-03-01T00:00:00Z")
}, {
"region" : "US",
"active" : "Y",
"date" : ISODate("2012-09-01T00:00:00Z")
}, {
"region" : "FR",
"active" : "N",
"date" : ISODate("2010-01-01T00:00:00Z")
}]
}
我想查找所有在 GB 区域有效发布的产品,并按 GB 发布日期对结果进行排序。
我尝试使用以下方法执行此操作:
db.product.find(
{ "release" : { "$elemMatch" : { "region" : "GB", "active" : "Y" } } }
).sort({ "release.date" : 1 });
这会找到正确的产品,但不会按匹配元素的发布日期排序(而是按数组中的最小发布日期排序)。
从我目前阅读的内容来看,似乎不可能按匹配元素的属性进行排序,这是正确的吗?
可以用聚合框架来完成吗,如果可以的话怎么做?