Golang 和 MongoDB 中的 ISODate 時間交互問題

MongoDB 中有一種時間格式數據 ISODate,參考如下:
mongodb中的時間

如果在 Golang 中查詢這條記錄,Golang用什麼類型的變量來保存呢?

查找 ISODate 時間字段

在 Golang 中可以使用 time.Time 數據類型來保存 MongoDB 中的 ISODate 時間。

type Model struct {
    Id   bson.ObjectId `bson:"_id,omitempty"`
    Time time.Time     `bson:"time"`
}
m := Model{}
err := c.Find(bson.M{"_id": bson.ObjectIdHex("572f3c68e43001d2c1703aa7")}).One(&m)
if err != nil {
    panic(err)
}
fmt.Printf("%+v\n", m)
// output: {Id:ObjectIdHex("572f3c68e43001d2c1703aa7") Time:2015-07-08 17:29:14.002 +0800 CST}

從輸出中可以看到 Golang 輸出的時間格式是 CST 時區,Golang 在處理的過程中將 ISO 時間轉換成了 CST 時間,從時間面板上來看也比 MongoDB 中的快上 8 個小時,這個是正常的。

那麼 Golang 做插入操作和或者時間比較操作的時候需要自己轉換時間戳嗎?答案是不需要的,來看下插入的例子。

插入時間

重新插入一條記錄,記錄的Time字段爲當前時間,在golang中可以通過time.Now獲取當前時間,查看輸出可以看到是CST的時間格式

now := time.Now()
fmt.Printf("%+v\n", now)
// output: 2016-05-12 14:34:00.998011694 +0800 CST
err = c.Insert(Model{Time: now})
if err != nil {
    panic(err)
}

查看 MongoDB 中的記錄

插入當前時間到 MongoDB:
插入當前時間到MongoDB

可以看到存儲到 MongoDB 中時間的自動轉換爲了 ISO 時間,時間少了 8 個小時。小結一下就是 Golang 和 MongoDB 中的時間交互不需要考慮額外的東西,因爲驅動都進行了轉換。

時間字符串轉成 time.Time

有時我們會將 time.Time 的時間以字符串的形式存儲,那麼要和 MongoDB 交互的時候就需要轉換 time.Time 格式

// 時間字符串轉到到time.Time格式
// 使用time.Parse方法進行轉換
timeString := "2016-05-12 14:34:00.998011694 +0800 CST"
t, err := time.Parse("2006-01-02 15:04:05.999999999 -0700 MST", timeString)
if err != nil {
    panic(err)
}
fmt.Printf("%+v\n", t)

代碼中比較難理解的就是 time.Parse 的第一個參數,這個其實是 Golang 當中的定義,詳細看下 time.Time.String() 的源碼就會明白了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章