撤消密集数据库中的级联删除
Undoing cascade deletions in a dense database
我有一个相当大的生产数据库系统,它基于一个大型节点层次结构,每个节点都有 10 多个关联模型。如果有人删除了树中相当高的一个节点,可能会删除数千个模型,如果删除是一个错误,恢复它们可能会非常困难。我正在寻找一种方法来为我提供一个简单的 'undo' 选项。
我试过使用 Django-reversion,但似乎为了获得我想要的功能(轻松恢复大型级联删除)它需要在每次修订时存储大量信息。当我创建初始修订时,该过程完成了不到 10%,它已经在我的数据库中使用了 8GB,这对我来说是行不通的。
那么,这个问题有标准的解决方案吗?或者自定义 Django-reversions 以适合我的用例的方法?
您要查找的内容称为软删除。将名为 deleted
且值为 false 的列添加到 table。现在,当您想执行 "delete" 时,改为将列 deleted
更改为 true。更新所有代码以不显示标记为已删除的行(或移动数据库 table 并将其替换为不显示它们的视图)。更改所有唯一约束以具有过滤器 WHERE deleted = false
这样您就不会遇到无法添加类似于用户在系统中看不到的内容的问题。
至于级联,您有两种选择。要么执行一个 ON UPDATE
触发器来更新子行,要么将 deleted
列添加到 FK 并将其定义为 ON UPDATE CASCADE
.
您将以额外一行的代价获得整个反向功能(并且无法删除内容以保存 space,除非您手动执行)。
我有一个相当大的生产数据库系统,它基于一个大型节点层次结构,每个节点都有 10 多个关联模型。如果有人删除了树中相当高的一个节点,可能会删除数千个模型,如果删除是一个错误,恢复它们可能会非常困难。我正在寻找一种方法来为我提供一个简单的 'undo' 选项。
我试过使用 Django-reversion,但似乎为了获得我想要的功能(轻松恢复大型级联删除)它需要在每次修订时存储大量信息。当我创建初始修订时,该过程完成了不到 10%,它已经在我的数据库中使用了 8GB,这对我来说是行不通的。
那么,这个问题有标准的解决方案吗?或者自定义 Django-reversions 以适合我的用例的方法?
您要查找的内容称为软删除。将名为 deleted
且值为 false 的列添加到 table。现在,当您想执行 "delete" 时,改为将列 deleted
更改为 true。更新所有代码以不显示标记为已删除的行(或移动数据库 table 并将其替换为不显示它们的视图)。更改所有唯一约束以具有过滤器 WHERE deleted = false
这样您就不会遇到无法添加类似于用户在系统中看不到的内容的问题。
至于级联,您有两种选择。要么执行一个 ON UPDATE
触发器来更新子行,要么将 deleted
列添加到 FK 并将其定义为 ON UPDATE CASCADE
.
您将以额外一行的代价获得整个反向功能(并且无法删除内容以保存 space,除非您手动执行)。