スライス内に含まれる値に基づいてレコードを取得するために MySQL のテーブルにクエリを実行する場合、SQLx を使用するとエラーが発生する場合があります。次の記事では、この問題の解決策を説明します。
次の方法で SQLx を使用してテーブルをクエリしようとすると、
var qids []int //fill qids dynamically err = database.SQL.Select(&quotes, "SELECT * FROM quote WHERE qid IN ", qids) if err != nil { log.Println(err) }
発生したエラーは次のとおりです。
sql: converting Exec argument #0's type: unsupported type []int, a slice quotes []
解決策は、提供されている In() ヘルパー関数を利用することです。 SQLx による。この関数を利用すると、引数をとって Rebind() を使用することでクエリを作成できます。修正されたコードは次のようになります。
var qids []int // fills qids on query dynamically query, args, err := sqlx.In("SELECT * FROM quote WHERE qid IN (?)", qids) if err != nil { log.Fatal(err) } // sqlx.In returns queries with the `?` bindvar, we can rebind it for our backend // query = database.SQL.Rebind(query) // database.SQL should be a *sqlx.DB err = database.SQL.Select(&quotes, query, args...) if err != nil { log.Fatal(err) } // or just in one line: err = database.SQL.Select(&quotes, database.SQL.Rebind(query), args...)
このトピックの詳細なガイダンスと例については、http://jmoiron.github.io/sqlx にある SQLx ドキュメントを参照してください。 /
以上がSQLx を使用して値のスライスを使用して MySQL に正しくクエリを実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。