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)
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 :
Préparez la requête en passant la tranche à la fonction In() :
query, args, err := sqlx.In("SELECT * FROM quote WHERE qid IN (?)", qids)
Reliez la requête pour votre base de données spécifique backend :
query = database.SQL.Rebind(query)
Exécuter le query :
err = database.SQL.Select(&quotes, query, args...)
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...)
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!