首页 > 后端开发 > Golang > 如何在 Go 中解析 MySQL 数据库中的时间?

如何在 Go 中解析 MySQL 数据库中的时间?

Barbara Streisand
发布: 2024-11-11 00:28:03
原创
997 人浏览过

How to Parse Time from a MySQL Database in Go?

在 Go 中从 MySQL 数据库解析时间

当尝试使用 Go 从 MySQL 数据库检索时间值时,您可能会遇到“不支持的驱动程序 ->”扫描对”错误。此问题源于 Go 的 MySQL 驱动程序的默认行为,不会自动将 DATE 和 DATETIME 值转换为 time.Time 对象。

要解决此问题,请将 parseTime=true 添加到 MySQL 连接字符串。此参数指示驱动程序为您执行必要的解析。

示例

db, err := sql.Open("mysql", "root:@/?parseTime=true")
if err != nil {
    panic(err)
}
defer db.Close()

var myTime time.Time
rows, err := db.Query("SELECT current_timestamp()")

if rows.Next() {
    if err = rows.Scan(&myTime); err != nil {
        panic(err)
    }
}

fmt.Println(myTime)
登录后复制

自定义解析

如果您不能使用 current_timestamp 并且必须使用 current_time,则您将需要自己解析。

type rawTime []byte

func (t rawTime) Time() (time.Time, error) {
    return time.Parse("15:04:05", string(t))
}

var myTime rawTime
rows, err := db.Query("SELECT current_time()")

if rows.Next() {
    if err = rows.Scan(&myTime); err != nil {
        panic(err)
    }
}

fmt.Println(myTime.Time())
登录后复制

这个自定义解析type 使用特定时间格式(本例中为“15:04:05”)将检索到的字节切片转换为 time.Time 对象。

以上是如何在 Go 中解析 MySQL 数据库中的时间?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板