一尘不染

您如何以UTC而不是本地时区JSON Marshall pq.NullTime?

go

我在postgres表中有日期。日期与UTC时区一起存储。

来自python的示例。

roster = Roster.objects.get(id=266438)
roster.start_timestamp
Out[11]: datetime.datetime(2018, 9, 7, 15, 0, tzinfo=<UTC>)

当我从go lib / pq中编组这些日期时,将以某种方式应用本地时区。

func (nt *pq.NullTime) MarshalJSON() ([]byte, error) {
    if !nt.Valid {
        return []byte("\"\""), nil
    }
    val := fmt.Sprintf("\"%s\"", nt.Time.Format("01/02/2006 15:04:05"))
    fmt.Println("Marshalling FMPDateTime", nt, val)
    return []byte(val), nil
}

日志示例:

Marshalling DateTime &{2018-09-08 00:30:00 +0930 ACST true} "09/08/2018 00:30:00"

2018-09-08 00:30:00 +0930 ACST 2018-09-07 15:00:00 UTC。

您如何以UTC而不是本地时区JSON Marshall pq.NullTime?


阅读 200

收藏
2020-07-02

共1个答案

一尘不染

图书馆通常time.Time使用本地时区构造值,但是时刻仍然是相同的,因此您不必为此担心。

如果要专门显示/输出UTC时区,则将时间“切换”到UTC时区。为此,您可以使用以下Time.UTC()方法:

val := fmt.Sprintf("\"%s\"", nt.Time.UTC().Format("01/02/2006 15:04:05"))

就这样。

还要注意,如果您NullTime的用户名无效,我宁愿输出JSON null而不是空字符串。

2020-07-02