当尝试使用 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中文网其他相关文章!