亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

為什么 go-pg 中的插入時間會改變

為什么 go-pg 中的插入時間會改變

Go
慕妹3242003 2023-08-21 14:21:57
我想使用 go-pg 將時間插入數據庫,但插入后值發生變化。toRound := time.Now()date := time.Date(toRound.Year(), toRound.Month(), toRound.Day(), 0, 0, 0, 0, toRound.Location())的值date是2020-03-18 00:00:00 +0700 WIB并使用插入go-pgreportMessage := &ReportMessage{                    Total:      ii,                    Date:            date                }_, err = p.ormer.Model(reportMessage).Returning("id").Insert()date插入后的值為2020-03-17 17:00:00+00:00:00看起來是因為時區的原因如何完全按照原始值插入時間而不受時區或其他因素的影響?
查看完整描述

2 回答

?
天涯盡頭無女友

TA貢獻1831條經驗 獲得超9個贊

嘗試在模型中使用 UTC 日期:

reportMessage.Date := date.UTC()


查看完整回答
反對 回復 2023-08-21
?
holdtom

TA貢獻1805條經驗 獲得超10個贊

另一種方法是讓 go-pg ORM 自動處理這個問題。如果您將模型定義為:


type ReportMessage struct {

    // Your data fields here


    CreatedAt time.Time `pg:"default:now()" json:"created_at"`

    UpdatedAt time.Time `pg:"default:now()" json:"updated_at`

}

now()這將告訴 go-pg / Postgres在插入新記錄時使用。然后,您可以在代碼中處理時區和內容,而數據庫將始終保留 UTC 時間戳。您可能需要使用 NTP 或類似方法正確配置服務器的時間。


查看完整回答
反對 回復 2023-08-21
  • 2 回答
  • 0 關注
  • 190 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號