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

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