Maison > développement back-end > Golang > Comment analyser le temps d'une base de données MySQL dans Go ?

Comment analyser le temps d'une base de données MySQL dans Go ?

Barbara Streisand
Libérer: 2024-11-11 00:28:03
original
998 Les gens l'ont consulté

How to Parse Time from a MySQL Database in Go?

Analyse du temps à partir d'une base de données MySQL dans Go

Lorsque vous essayez de récupérer une valeur temporelle à partir d'une base de données MySQL à l'aide de Go, vous pouvez rencontrer un "pilote non pris en charge -> Erreur "Scanner la paire". Ce problème provient du comportement par défaut du pilote MySQL de Go qui ne convertit pas automatiquement les valeurs DATE et DATETIME en objets time.Time.

Pour résoudre ce problème, ajoutez parseTime=true à votre chaîne de connexion MySQL. Ce paramètre demande au pilote d'effectuer l'analyse nécessaire pour vous.

Exemple

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)
Copier après la connexion

Analyse personnalisée

Si vous ne pouvez pas utiliser current_timestamp et devez utiliser current_time, vous devez effectuer l'analyse vous-même.

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())
Copier après la connexion

Ce type d'analyse personnalisé convertit le tranche d'octets en un objet time.Time utilisant un format d'heure spécifique ("15:04:05" dans ce cas).

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal