PostgreSQLでのデータ変更時の可視性規則は以下のとおりです。問い合わせの実行中、その問い合わせ自身によって(SQL関数、SPI関数、トリガ経由で)なされたデータの変更はその問い合わせのスキャンからは不可視となります。たとえば、以下のような問い合わせでは、挿入されたタプルはSELECTスキャンからは不可視となります。
INSERT INTO a SELECT * FROM a
このため、この問い合わせはデータベースのテーブルを再帰処理することなく(もちろん、一意性インデックス規則にしたがって)二重化します。
問い合わせQによりなされる変更は、問い合わせQの後に開始した問い合わせに対しては可視です。この問い合わせがQの内側で(Qの実行中に)開始されたのか、Qの実行が終わってから開始されたのかについては問いません。