ホームページ >バックエンド開発 >Golang >SQLx の「In()」関数を使用して、ID のスライスを使用して MySQL にクエリを実行する方法

SQLx の「In()」関数を使用して、ID のスライスを使用して MySQL にクエリを実行する方法

Susan Sarandon
Susan Sarandonオリジナル
2024-11-28 09:54:10776ブラウズ

How to Use SQLx's `In()` Function to Query MySQL with a Slice of IDs?

SQLx を使用してスライスから IN で MySQL をクエリする

SQLx では、スライスに格納された値を使用してテーブルをクエリする必要があります。これは、In() ヘルパー関数を利用することで実現できます。

コード例

指定されたエラーに対処するには、次のコード スニペットを使用できます。

var qids []int

// Populate qids dynamically

query, args, err := sqlx.In("SELECT * FROM quote WHERE qid IN (?)", qids)
if err != nil {
    log.Fatal(err)
}

database.SQL := sqlx.MustConnect("driver_name", "dsn")
query = database.SQL.Rebind(query)  // Assuming database.SQL is a *sqlx.DB

err = database.SQL.Select(&quotes, query, args...)
if err != nil {
    log.Fatal(err)
}

機能

  • In() 関数は、引数を取得して再バインドすることでクエリを準備します。
  • Rebind() は、特定のデータベース バックエンドに適切なバインド変数を使用するようにクエリを変換します。
  • In() と Rebind() を組み合わせることで、クエリが準備され、実行用に最適化されます。 .

追加リソース

さらに参照するには、次のドキュメントを参照してください。推奨:

  • SQLx ドキュメント: http://jmoiron.github.io/sqlx/
  • In() 関数ドキュメント: https://godoc.org/github.com/ jmoiron/sqlx#In
  • Rebind() 関数のドキュメント: https://godoc.org/github.com/jmoiron/sqlx#Rebind

以上がSQLx の「In()」関数を使用して、ID のスライスを使用して MySQL にクエリを実行する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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