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

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

Patricia Arquette
リリース: 2024-12-04 05:06:10
オリジナル
618 人が閲覧しました

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 サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート