Maison > développement back-end > Golang > Comment puis-je interroger des données avec des types de colonnes inconnus dans le package SQL de Go ?

Comment puis-je interroger des données avec des types de colonnes inconnus dans le package SQL de Go ?

Barbara Streisand
Libérer: 2024-11-03 01:57:02
original
347 Les gens l'ont consulté

How Can I Query Data With Unknown Column Types in Go's SQL Package?

Exploration des requêtes ad hoc dans le package SQL de Go

Bien que la documentation suggère que l'interrogation de données dans Go à l'aide du package SQL nécessite de connaître le nombre de colonnes et types au moment de la compilation, ce n'est pas strictement vrai. Le type sql.Rows offre une solution pour les requêtes SQL flexibles et ad hoc.

Récupération dynamique des métadonnées de colonnes

La méthode Columns dans sql.Rows fournit une liste des noms de colonnes de résultats. Cela vous permet de déterminer dynamiquement le nombre de colonnes renvoyées par une requête arbitraire.

Analyse des types de données inconnus

La méthode Scan prend en charge l'analyse des valeurs de types inconnus dans un tranche d'octets brute (*[]byte) ou une valeur d'interface{}. Cela vous permet de récupérer des données de colonne sans prédéfinir leur type.

Travailler avec des requêtes ad hoc

En combinant ces techniques, vous pouvez exécuter des requêtes ad hoc et récupérer des données dans une tranche de valeurs d'interface{} :

<code class="go">columnNames, err := rows.Columns()
if err != nil {
    // Handle error
}
columns := make([]interface{}, len(columnNames))
columnPointers := make([]interface{}, len(columnNames))
for i := 0; i < len(columnNames); i++ {
    columnPointers[i] = &columns[i]
}
if err := rows.Scan(columnPointers...); err != nil {
    // Handle error
}</code>
Copier après la connexion

Après cela, la tranche de colonnes contiendra les valeurs décodées pour toutes les colonnes de la ligne de résultat. En tirant parti des méthodes Columns et Scan, vous pouvez gérer efficacement les requêtes ad hoc dans le package SQL de Go.

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