在我的Mongo收藏集中,我需要比较三个日期,并找到最近的一个。我想知道是否有捷径或本机MongoDB的方式?
在香草JS中比较两个日期时,我可以这样:
let compareDates = (date1, date2) => {
if (date1>date2) return ("Date1 > Date2");
else if (date1<date2) return ("Date2 > Date1");
else return ("Date1 = Date2");
}
console.log(compare_dates(new Date('11/14/2018 00:00'), new Date('11/14/2018 00:00')));
console.log(compare_dates(new Date('11/14/2018 00:01'), new Date('11/14/2018 00:00')));
console.log(compare_dates(new Date('11/14/2018 00:00'), new Date('11/14/2018 00:01')));
...但是要花很多时间才能约会。有没有一种比较三个日期并返回最近日期的较短方法?
我们假设这样的简化模型:
{
_id: '123',
date1: {
type: Date,
},
date2: {
type: Date,
},
date3: {
type: Date,
}
}
答案 0 :(得分:2)
假设您的模型如下所示:
{
date1: ISODate("1990-01-01T00:00:00Z"),
date2: ISODate("1980-01-01T00:00:00Z"),
date3: ISODate("1970-01-01T00:00:00Z")
}
您只需使用$max即可获取最近的日期:
db.collection.aggregate([
{
$project: {
recentDate: { $max: [ "$date1", "$date2", "$date3" ] }
}
}
])
答案 1 :(得分:0)
只需添加一些POJS解决方案,Math.max即可运行,但返回一个时间值。或者,将它们排序为一个数组并得到最后一个:
var dates = [
new Date('2018-01-01'),
new Date('2018-01-03'),
new Date('2018-01-02')
];
// Returns a new Date
console.log(new Date(Math.max(...dates)));
// Returns one of the dates, sorts and shortens the array
console.log(dates.sort((a,b)=>a-b).pop());
// Returns a reference to one of the dates, sorts but doesn't shorten the array
console.log(dates.sort((a,b)=>a-b).slice(-1)[0]);