我在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?
图书馆通常time.Time使用本地时区构造值,但是时刻仍然是相同的,因此您不必为此担心。
time.Time
如果要专门显示/输出UTC时区,则将时间“切换”到UTC时区。为此,您可以使用以下Time.UTC()方法:
Time.UTC()
val := fmt.Sprintf("\"%s\"", nt.Time.UTC().Format("01/02/2006 15:04:05"))
就这样。
还要注意,如果您NullTime的用户名无效,我宁愿输出JSON null而不是空字符串。
NullTime
null