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 (*[]octet) 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{} :
columnNames, err := rows.Columns()
if err != nil {
// Handle error
}
columns := make([]interface{}, len(columnNames))
columnPointers := make([]interface{}, len(columnNames))
for i := 0; i 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.
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3