ホームページ > バックエンド開発 > Golang > PostgreSQL で Go `pq` ドライバーを使用して IN ルックアップを適切に実行する方法

PostgreSQL で Go `pq` ドライバーを使用して IN ルックアップを適切に実行する方法

Barbara Streisand
リリース: 2024-12-26 12:06:14
オリジナル
302 人が閲覧しました

How to Properly Execute an IN Lookup with a Go `pq` Driver in PostgreSQL?

Go を使用した SQL での IN ルックアップの実行

Go を使用して Postgres で IN ルックアップを実行すると、2 番目の引数に必要なパラメータを決定する際に問題が発生する可能性があります。 。解決策を理解するために、コード スニペットとその目的の機能を詳しく見てみましょう。

コード:

stmt, err := db.Prepare("SELECT * FROM awesome_table WHERE>
ログイン後にコピー
ログイン後にコピー

は、次の SQL クエリを実行することを目的としています:

SELECT * FROM awesome_table WHERE>
ログイン後にコピー
ログイン後にコピー

重要な問題は、Go が SQL クエリの 2 番目の引数として何を期待しているかです。答えは、Postgres 固有のドライバーによって提供される pq.Array 型、つまり pq.

stmt, err := db.Prepare("SELECT * FROM awesome_table WHERE>
ログイン後にコピー
ログイン後にコピー

を利用することにあります。このコードは、id が 10 に設定され、other_field が 10 の要素と比較される SQL ステートメントを準備します。 「this」と「that」を含む配列。結果の SQL クエリは次のようになります。

SELECT * FROM awesome_table WHERE>
ログイン後にコピー
ログイン後にコピー

このコードではプリペアド ステートメントが使用されていることに注意することが重要です。そのため、セキュリティ上の理由から入力をサニタイズすることが不可欠です。

以上がPostgreSQL で Go `pq` ドライバーを使用して IN ルックアップを適切に実行する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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