ホームページ >バックエンド開発 >Golang >SQLx を使用して値のスライスを使用して MySQL に正しくクエリを実行するにはどうすればよいですか?

SQLx を使用して値のスライスを使用して MySQL に正しくクエリを実行するにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-12-04 05:06:10625ブラウズ

How to Correctly Query MySQL with a Slice of Values Using SQLx?

スライスの値を使用して MySQL にクエリを実行する SQLx

スライス内に含まれる値に基づいてレコードを取得するために 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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。