F.34. pg_surgery — 对关系数据执行低级手术#
pg_surgery
模块提供各种函数,用于对损坏的关系执行手术。这些函数在设计上是不安全的,使用它们可能会损坏(或进一步损坏)您的数据库。例如,这些函数很容易被用来使表与其自己的索引不一致,导致UNIQUE
或FOREIGN KEY
约束冲突,甚至使元组可见,当读取时,将导致数据库服务器崩溃。应非常谨慎地使用它们,并且仅作为最后的手段。
F.34.1. 函数#
heap_force_kill(regclass, tid[]) 返回 void
heap_force_kill
将 “已使用” 行指针标记为 “已死”,而无需检查元组。此函数的预期用途是强制删除无法通过其他方式访问的元组。例如test=> select * from t1 where ctid = '(0, 1)'; ERROR: could not access status of transaction 4007513275 DETAIL: Could not open file "pg_xact/0EED": No such file or directory.
test=# select heap_force_kill('t1'::regclass, ARRAY['(0, 1)']::tid[]); heap_force_kill
(1 row)
test=# select * from t1 where ctid = '(0, 1)'; (0 rows)
heap_force_freeze(regclass, tid[]) 返回 void
heap_force_freeze
将元组标记为冻结,而无需检查元组数据。此函数的预期用途是让由于损坏的可见性信息而无法访问的元组变得可访问,或者让由于损坏的可见性信息而无法成功对表进行真空操作的元组变得可访问。例如test=> vacuum t1; ERROR: found xmin 507 from before relfrozenxid 515 CONTEXT: while scanning block 0 of relation "public.t1"
test=# select ctid from t1 where xmin = 507; ctid
(0,3) (1 row)
test=# select heap_force_freeze('t1'::regclass, ARRAY['(0, 3)']::tid[]); heap_force_freeze
(1 row)
test=# select ctid from t1 where xmin = 2; ctid
(0,3) (1 row)
F.34.2. 作者#
Ashutosh Sharma<[[email protected]](/cdn-cgi/l/email-protection#dbbaa8b3aef5b8b4beb0e3e39bbcb6bab2b7f5b8b4b6)>