最新消息:yaf表单扩展中新增加了浮点数、日期和集合的校验。php yaf框架扩展实践三——表单

golang和mongodb中的ISODate时间交互问题

Golang 1046浏览 0评论

mongodb中有一种时间格式数据ISODate,参考如下:

mongodb中ISODate时间

mongodb中ISODate时间

如果在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()的源码就会明白了。

转载请注明:快乐编程 » golang和mongodb中的ISODate时间交互问题

发表我的评论
取消评论

表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址