由于 DELETE 语法的限制,在 PostgreSQL 中通过排序删除行可能是一个挑战。由于缺少主键,这个问题变得更加复杂,使得子查询解决方案变得不切实际。
为了解决这一挑战,您可以利用 ctid 字段,它是表中每一行的唯一标识符。通过利用 ctid,您可以根据排序条件构造一个针对特定行进行删除的查询:
DELETE FROM ONLY logtable WHERE ctid IN ( SELECT ctid FROM logtable ORDER BY timestamp LIMIT 10 );
ctid 字段为每个行版本提供唯一标识符。但是,需要注意的是,如果行被 VACUUM FULL 更新或移动,它可能会发生变化。此外,如果日志表具有继承表,则 DELETE FROM ONLY 子句可防止从后代表中意外删除行。
如果日志表已分区,则有必要在查询中包含 tableoid 以确保删除仅发生在预期的分区:
DELETE FROM logtable WHERE (tableoid,ctid) IN ( SELECT tableoid,ctid FROM logtable ORDER BY timestamp LIMIT 10 );
使用这些技术,您可以根据排序标准有效地删除固定数量的行,同时保留精确删除,确保删除指定数量的行,无论重复的时间戳如何。
以上是如何在没有主键的情况下删除 PostgreSQL 中特定数量的已排序行?的详细内容。更多信息请关注PHP中文网其他相关文章!