返回午夜后创建的文档

Return documents created since midnight

本文关键字:文档 创建 午夜 返回      更新时间:2023-09-26

我想查找自午夜以来创建的所有文档,而不考虑用户的时区。如果用户在太平洋时间,它应该显示自太平洋午夜以来的所有文档。与东部时间相同。

我在东部时间,这对我很有用:

var d = new Date();
    var midnight = d.setHours(0,0,0,0); // last midnight
    var count = Items.find({
      username: Meteor.user().username,
      createdAt: { $gt: midnight }
    }).count();

但我的客户在CST,这对他不起作用。相反,它显示了自前一天美国中部时间晚上10点或11点以来创建的文档。所以这对我来说似乎是一个时区问题。

假设这只是一个客户端问题(所有时间都存储在服务器上的UTC中),那么您可以通过执行以下操作获得用户当前时区午夜的UTC调整时间:

var now = new Date();
var midnight = new Date(now.getFullYear(), now.getMonth(), now.getDate());
var midnight_utc = new Date(Date.UTC(now.getFullYear(), now.getMonth(), now.getDate()));

看看这把小提琴:https://jsfiddle.net/Lbk1vo0j/1/例如,对于我当前的时区(东部),我得到了现在、午夜和午夜_utc的以下值(当使用toLocaleString()方法打印Date对象时):

3/30/2015, 3:06:39 PM
3/30/2015, 12:00:00 AM
3/29/2015, 8:00:00 PM

尝试setUTCHours(0, 0, 0, 0);。它得到的协调世界时应该对每个用户都是一样的。

我有类似的要求,所以我使用了以下方法,

  1. 创建了将datetime映射到_id的函数
  2. 用那个id获取我的数据

我使用的功能是

function objectIdWithTimestamp(timestamp){
    // Convert string date to Date object (otherwise assume timestamp is a date)
    if (typeof(timestamp) == 'string') { timestamp = new Date(timestamp); }
    // Convert date object to hex seconds since Unix epoch
    var hexSeconds = Math.floor(timestamp/1000).toString(16);
    // Create an ObjectId with that hex timestamp
    var constructedObjectId = ObjectId(hexSeconds + "0000000000000000");
    return constructedObjectId
}

使用它

db.collection.find({_id:{$gte:objectIdWithTimestamp(Y/m/d H:i:s)}})

我会建议您尝试moment库并解决时区问题。在执行任何客户端代码的地方,获取其最后一个午夜时间,将其转换为UTC时间&然后轻松地从MongoDb中检索信息。少数时刻库使用示例,有关更多详细信息,请参阅此处

var str = "2013-12-01"
moment.tz(str, "America/Los_Angeles").format(); // 2013-06-01T00:00:00-07:00
moment.tz(str, "America/New_York").format();    // 2013-06-01T00:00:00-04:00

午夜后的分钟数

您可以从用户的角度获取自午夜以来的分钟数。请尝试使用它查询服务器以了解自x分钟前以来的更改。

var d = new Date();
console.log(d);
var now = d.getTime();
d.setHours(0,0,0,0);
var midnight = d.getTime();
var minutes_ago = Math.floor((now-midnight) / (60 * 1000));
console.log(minutes_ago);

输出:

Date {Thu Apr 02 2015 16:12:54 GMT-0700 (PDT)}
972

这应该有效:

var d = new Date();
var midnight = d.setUTCHours(0,0,0,0); // last midnight everywhere
var count = Items.find({
  username: Meteor.user().username,
  createdAt: { $gt: midnight }
}).count();