Có lẽ bạn có thể sử dụng tính năng tổng hợp và ngày kết thúc giả tạo cao:
c = db.foo.aggregate([
{$project: {
next_time: 1,
nlt: { $ifNull: [ "$next_time", new ISODate("9000-01-01") ] }
}
}
,
{$sort: { "nlt": 1}}
]);
c.forEach(function(r) { printjson(r); });
Ngoài ra, nếu phần lớn tài liệu có rỗng và bạn không muốn xử lý những tài liệu đó, hãy lọc chúng ra và chỉ cần $sort
phần còn lại:
db.foo.aggregate([
{$match: {"nt": {$exists: true}}}
,
{$sort: { "nt": 1}}
]);