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

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

Barbara Streisand
Barbara Streisand原创
2024-11-11 00:28:03999浏览

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn