比较三个日期以获取MongoDB中的最新信息

时间:2018-10-19 13:10:43

标签: javascript mongodb date

在我的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,
    }
}

2 个答案:

答案 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]);