Maison > développement back-end > Golang > Comment éviter les erreurs « type non pris en charge []int » lors de l'utilisation de SQLx dans Go ?

Comment éviter les erreurs « type non pris en charge []int » lors de l'utilisation de SQLx dans Go ?

Barbara Streisand
Libérer: 2024-12-06 06:58:14
original
817 Les gens l'ont consulté

How to Avoid

Comment implémenter des requêtes SQL à l'aide de la bibliothèque SQLx dans Go

Lorsque vous travaillez avec des requêtes SQL dans une tranche, vous pouvez rencontrer des erreurs telles que "conversion de l'argument Exec #0 type : type non pris en charge []int, une tranche." Pour résoudre ce problème, vous pouvez utiliser la fonction d'assistance In() fournie par la bibliothèque sqlx.

La syntaxe de In() est la suivante :

query, args, err := sqlx.In(query, args)
Copier après la connexion

où la requête est la requête d'origine string et args sont la tranche de valeurs à interpoler dans la requête.

Pour utiliser In(), suivez ces étapes :

  1. Préparez la requête en passant la tranche à la fonction In() :

    query, args, err := sqlx.In("SELECT * FROM quote WHERE qid IN (?)", qids)
    Copier après la connexion
  2. Reliez la requête pour votre base de données spécifique backend :

    query = database.SQL.Rebind(query)
    Copier après la connexion
  3. Exécuter le query :

    err = database.SQL.Select(&quotes, query, args...)
    Copier après la connexion

Vous pouvez également combiner les étapes de préparation et d'exécution sur une seule ligne :

err = database.SQL.Select(&quotes, database.SQL.Rebind(query), args...)
Copier après la connexion

Pour des exemples et une documentation supplémentaires, reportez-vous au fichier sqlx documentation de la bibliothèque sur http://jmoiron.github.io/sqlx/.

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!

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