gpt4 book ai didi

node.js - Mongodb 按今天的日期查找创建的结果

转载 作者:IT老高 更新时间:2023-10-28 13:05:20 26 4
gpt4 key购买 nike

我有这个查询来获得当月的结果。但我想得到今天的结果。

var start = new Date(2010, 11, 1);
var end = new Date(2010, 11, 30);

db.posts.find({created_on: {$gte: start, $lt: end}});

最好的方法是什么?

最佳答案

您的开始日期对象应以 00:00:00.000(毫秒精度)保存当前日期时间小时,并将今天日期的小时数设置为 23:59:59.999:

var start = new Date();
start.setHours(0,0,0,0);

var end = new Date();
end.setHours(23,59,59,999);

然后像往常一样在 MongoDB 查询运算符中传递修改后的日期对象:

db.posts.find({created_on: {$gte: start, $lt: end}});

如果您使用的是 dayjs date utility库,这可以通过使用 startOf() 来完成和 endOf() dayjs 当前日期对象上的方法,将字符串 'day' 作为参数传递:

const start = dayjs().startOf('day'); // set to 12:00 am today
const end = dayjs().endOf('day'); // set to 23:59 pm today

您也可以使用$expr如下:

db.posts.find({
$expr: {
$eq: [
{ $dateToString: { format: '%Y-%m-%d', date: '$$NOW' } },
{ $dateToString: { format: '%Y-%m-%d', date: '$created_on' } },
],
},
})

关于node.js - Mongodb 按今天的日期查找创建的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29327222/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com