ホームページ >バックエンド開発 >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 オブジェクトに自動的に変換しないことに起因します。

この問題を解決するには、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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。