dongzhuang2030 2019-07-15 15:07
浏览 193

为什么MongoDB无法正确存储日期?

In my form, I need to enter a date of purchase, I enter it in this format: DD/MM/YYYY (ie. 15/07/2019).

This field is a Mongo Date field.

But, when I enter this date : 01/02/2015, instead of : "2015-02-01T00:00:00.000+00:00", it saves "2015-01-31T23:00:00.000+00:00".

This is a problem because when I query and reorder the purchases by month, this purchase appears in January instead of February.

Maybe this is a Time zone problem but I think there is no way to change the default UTC Time zone in Mongo.

If so, I'm wondering what is the logic I should adopt in my controller?

UPDATE

I may have found a solution:

On my controller, before storing the date in the collection:

$string = '01/02/2015';
$datetime = DateTime::createFromFormat('j/m/Y', $string, new DateTimeZone('UTC'));

$datetime->setTime(00, 00, 00);
echo $datetime->format(DateTime::RFC3339_EXTENDED);

// Result: 2015-02-01T00:00:00.000+00:00

Then I store the result in the collection.

This is probably way too much, but is there a better solution?

  • 写回答

1条回答 默认 最新

  • douxi3404 2019-07-15 15:28
    关注
       db.getCollection('my_collection').aggregate([
           { $project: { title: 1, date: { $add: [ "$date", 60*60000 ] } } }
       ])
    

    Store date in iso format that is ISODate("2015-01-31T23:00:00.000") and query like mentioned above.

    评论

报告相同问题?

悬赏问题

  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line