PL/pgSQL: 行が存在するかどうかを効率的にチェックします
PL/pgSQL では、テーブル内の行の存在を確認するのが一般的なタスクです。 SELECT クエリを使用して整数を取得してブール値に変換しようとしましたが、この方法は非効率的でエラーが発生しやすくなります。より効率的で簡潔な解決策は次のとおりです:
最も簡単な方法は、EXISTS 演算子を使用することです。 EXISTS は、サブクエリに少なくとも 1 つの一致する行が存在する場合は true を返し、それ以外の場合は false を返します。これにより、行の存在を確認する明確かつ簡潔な方法が提供されます:
<code class="language-sql">IF EXISTS (SELECT FROM people p WHERE p.person_id = my_person_id) THEN -- 执行某些操作 END IF;</code>
EXISTS の利点:
COUNT との比較:
COUNT を使用した元のアプローチでは、対象となるすべての行をスキャンしてその数を決定する必要があります。これは、特にインデックスが存在する場合、効率が低下する可能性があります。一方、EXISTS は、最初に一致する行が見つかるとすぐに終了できます。
注: 一致する行の数が必要な場合は、結果を 1 行に制限する条件を指定して COUNT を使用します。例:
<code class="language-sql">IF (SELECT COUNT(*) FROM people p WHERE p.person_id = my_person_id) > 0 THEN -- 执行某些操作 END IF;</code>
以上がPL/pgSQL で行の存在を効率的に確認するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。