主キーを使用しない PostgreSQL での行削除順序の保持
MySQL では、クエリ DELETE FROM ログテーブル ORDER BY タイムスタンプ LIMIT 10;ソート順序を維持しながら、指定された数の行をテーブルから簡単に削除します。ただし、PostgreSQL では、特にテーブルに主キーがない場合に、削除構文での順序付けや制限を禁止することで課題が生じます。
主キー制約の克服
回避するにはこの障害に対して、PostgreSQL は ctid を利用するソリューションを提供します。 ctid は、テーブル内の各行の物理的な位置を表します。これは永続的な識別子ではありませんが、テーブルごとに一意であるため、行削除の実行可能な代替手段となります。
ctid の利用
ctid を利用して、事前に定義された ID を削除できます。次のクエリでソートされた行の数:
DELETE FROM ONLY logtable WHERE ctid IN ( SELECT ctid FROM logtable ORDER BY timestamp LIMIT 10 );
DELETE FROM ONLY は、削除操作を指定されたテーブルに制限し、継承されたテーブルからの不用意な削除を防ぎます。
パーティションとセキュリティ設定の処理
ログテーブルがパーティション化されている場合は、以下を含める必要があります。クエリ内の tableoid (テーブル ID) は、複数のクエリで削除が発生するのを防ぎます。
さらに、セキュリティ ポリシーが実装されている場合は、適切なアクセス権を確保するためにクエリを調整する必要がある場合があります。
追加メモ
です。 VACUUM FULL によって行が更新または移動されると、ctid が変更される可能性があることを覚えておくことが重要です。 ctid を長期的な行識別子として使用する場合は、この制限に留意してください。
以上が主キーを使用せずに PostgreSQL の行を特定の順序で削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。