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>
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!