gpt4 book ai didi

javascript - 将存储在mysql(utc格式)中的momentjs datetime格式化为Local DateTime

转载 作者:行者123 更新时间:2023-11-29 04:39:34 25 4
gpt4 key购买 nike

我在表中有一个名为 registerdate 的列,在 mysql 中类型为 datatime。

假设现在时间是本地时间“2015-10-10 06:00:00”。

我在数据库中存储 UTC 时间,因此它将转换为“2015-10-10 00:30:00”,因为本地时间是格林威治标准时间 +530。所以正确的时间存储在数据库中。

如何在检索时将注册时间转换为本地时间。

这是我在将日期时间保存到 db 之前转换的方式

moment.utc(new Date()).format("YYYY-MM-DD HH:mm:ss")

这就是我正在尝试将其转换回本地时间。

moment.utc(registerdate, "YYYY-MM-DD HH:mm:ss").local().format("HH:mm:ss")

这不会更改保存日期并呈现与存储在数据库中相同的日期。

第二种方法:它进一步减去 5:30 小时而不是增加它。

moment.utc(_obj[i].StartTime).format("HH:mm:ss")

我哪一步做错了。

最佳答案

我不认为使用 JavaScript 在 MySQL 中保存日期时间是个好主意。我认为最好使用 MySQL 函数 UTC_TIMESTAMP() .例如:

INSERT INTO `ITEMS` (`name`, `date_add`) VALUES ('item name', UTC_TIMESTAMP());

现在,当您从 MySQL 检索 UTC 日期时间时,您可以将其转换为 Moment 对象,如下所示:

var utc = moment.utc(MYSQL_DATETIME, 'YYYY-MM-DD HH:mm:ss');
var local = utc.local();
// var local = moment.utc(MYSQL_DATETIME, 'YYYY-MM-DD HH:mm:ss').local();
console.log( local.format("HH:mm:ss") ); // 15:54:31
console.log( local.fromNow() ); // a minute ago

我没有发现您的代码有任何问题。也许是应用程序方面的问题(PHP?)。

还有一点。使用不带参数的方法 utc() 与调用 utc(new Date()) 相同。因此,您可以简单地在转换为 MySQL 日期时间时使用它:

//moment.utc(new Date()).format("YYYY-MM-DD HH:mm:ss")
moment.utc().format("YYYY-MM-DD HH:mm:ss")

注意:请原谅我的英语不好。

关于javascript - 将存储在mysql(utc格式)中的momentjs datetime格式化为Local DateTime,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32629069/

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