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

时间:2018-09-26 07:07:01

标签: postgresql 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?

1 个答案:

答案 0 :(得分:1)

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

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

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

仅此而已。

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