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