Go を使用して MySQL データベースから時間値を取得しようとすると、「サポートされていないドライバー ->」が発生する場合があります。スキャンペア」エラー。この問題は、Go の MySQL ドライバーのデフォルト動作が DATE および DATETIME 値を time.Time オブジェクトに自動的に変換しないことに起因します。
この問題を解決するには、MySQL 接続文字列に parseTime=true を追加します。このパラメータは、必要な解析を実行するようにドライバに指示します。
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())
このカスタム解析タイプ取得したバイト スライスを、特定の時刻形式 (この場合は「15:04:05」) を使用して time.Time オブジェクトに変換します。
以上がGo で MySQL データベースから時間を解析するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。