PostgreSQL – 禁用约束

PostgreSQL – 禁用约束,第1张

概述我有一个约500万行的表,它有一个fk约束,引用另一个表的主键(约500万行)。 我需要从两个表中删除大约75000行。我知道,如果我尝试这样做的fk约束启用它将采取不可接受的时间量。 来自Oracle背景我的第一个想法是禁用约束,做删除&然后重新启用约束。 PostGres似乎让我禁用约束触发器,如果​​我是一个超级用户(我不是,但我正在以拥有/创建对象的用户登录),但似乎不是我想要的。 另一个 我有一个约500万行的表,它有一个fk约束,引用另一个表的主键(约500万行)。

我需要从两个表中删除大约75000行。我知道,如果我尝试这样做的fk约束启用它将采取不可接受的时间量。

来自Oracle背景我的第一个想法是禁用约束,做删除&然后重新启用约束。 PostGres似乎让我禁用约束触发器,如果​​我是一个超级用户(我不是,但我正在以拥有/创建对象的用户登录),但似乎不是我想要的。

另一个选项是删除约束,然后恢复它。我担心重建约束会考虑到我的表的大小。

有什么想法吗?

编辑:在比利的鼓励之后,我试着做删除,而不改变任何约束,它需要超过10分钟。但是,我发现我想从中删除的表有一个自引用外键…重复(&非索引)。

最后更新 – 我删除了自我参考外键,我的删除,并添加回来。比利的权利,但不幸的是,我不能接受他的评论作为答案!

根据以前的评论,它应该是一个问题。也就是说,有一个命令可能是你正在寻找的 – 它将设置约束以延迟,因此他们检查COMMIT,而不是每次删除。如果你只是对所有的行做一个大的删除,它不会有什么区别,但如果你做的是块,它会的。
SET CONSTRAINTS ALL DEFERRED

是你在寻找的情况下。请注意,约束必须标记为DEFERRABLE,然后才能延迟。例如:

ALTER table table_name  ADD CONSTRAINT constraint_uk UNIQUE(column_1,column_2)  DEFERRABLE INITIALLY IMMEDIATE;

然后可以如下在事务或函数中推迟约束:

CREATE OR REPLACE FUNCTION f() RETURNS voID AS$BODY$BEGIN  SET CONSTRAINTS ALL DEFERRED;  -- Code that temporarily violates the constraint...  -- UPDATE table_name ...END;$BODY$  LANGUAGE plpgsql VolATILE  COST 100;
总结

以上是内存溢出为你收集整理的PostgreSQL – 禁用约束全部内容,希望文章能够帮你解决PostgreSQL – 禁用约束所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1171806.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存