1

我有一个相当大的生产数据库系统,基于大量的节点层次结构,每个节点都有 10 多个关联模型。如果有人删除了树中相当高的节点,可能会删除数千个模型,如果删除是错误的,那么恢复它们可能会非常困难。我正在寻找一种方法来给我一个简单的“撤消”选项。

我尝试过使用 Django-reversion,但似乎为了获得我想要的功能(轻松恢复大型级联删除),它需要在每个修订版中存储一堆信息。当我创建初始修订时,该过程完成不到 10%,并且它已经在我的数据库中使用了 8GB,这对我来说不起作用。

那么,这个问题有标准的解决方案吗?或者一种自定义 Django-reversions 以适应我的用例的方法?

4

1 回答 1

3

您要查找的内容称为软删除。向表中添加一个名为deletedfalse 的列。现在,当您想要执行“删除”时,请将列更改deleted为 true。更新所有代码以不显示标记为已删除的行(或移动数据库表并将其替换为不显示它们的视图)。将所有唯一约束更改为具有过滤器WHERE deleted = false,这样您就不会遇到无法添加类似于用户在系统中看不到的内容的问题。

至于级联,您有两个选择。要么执行ON UPDATE将更新子行的触发器,要么将列添加deleted到 FK 并将其定义为ON UPDATE CASCADE.

您将获得完整的反向功能,代价是额外的一行(除非您手动执行,否则无法删除内容以节省空间)。

于 2016-05-30T17:07:28.953 回答