Mungkin Anda dapat menggunakan agregasi dan tanggal akhir yang dibuat-buat:
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); });
Atau, jika sebagian besar materi memiliki nol dan Anda tidak ingin berurusan dengan dokumen tersebut sama sekali, maka filter dan cukup $sort
sisanya:
db.foo.aggregate([
{$match: {"nt": {$exists: true}}}
,
{$sort: { "nt": 1}}
]);