ホームページ > バックエンド開発 > Golang > Go を使用して PostgreSQL で IN ルックアップを効率的に実行するにはどうすればよいですか?

Go を使用して PostgreSQL で IN ルックアップを効率的に実行するにはどうすればよいですか?

Linda Hamilton
リリース: 2024-12-31 02:15:09
オリジナル
257 人が閲覧しました

How to Efficiently Perform IN Lookups in PostgreSQL with Go?

Go を使用した SQL での IN ルックアップによるクエリ

Go を使用して PostgreSQL で IN ルックアップを実行する場合、SQL クエリの 2 番目のパラメータは次のとおりです。 Postgres 固有の配列オブジェクトにする必要があります。これにより、指定されたフィールドに対して複数の値を効率的に評価できるようになります。

例として、次の SQL クエリを考えてみます。

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

Go では、pq ドライバーを使用して、このクエリを次のように構築できます。

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

pq.Array 型を使用すると、文字列のスライスから配列オブジェクトを作成できます。この例では、$2 パラメータは次のようにレンダリングされます:

'{"this", "that"}'
ログイン後にコピー

これは実質的に次の SQL に変換されます:

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

このアプローチでは準備されたステートメントが使用され、次のことが保証されることに注意してください。ユーザー入力は SQL インジェクション攻撃を防ぐためにサニタイズされます。

以上がGo を使用して PostgreSQL で IN ルックアップを効率的に実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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