我去年在一个大项目里工作,那就是教育管理系统!我的团队在开发过程中解决了很多问题。但我们有一个问题,现在我又明白了。
问题是:
如果有引用的记录可以从软件接口中删除,如何设计数据库结构?
简单的示例:假设您有表:
Students, StudentClass, Marks, Classes。因此,如果我尝试从'Classes'表中删除记录,这是不可能的,因为'StudentClass'表具有对'Classes'表的引用。当然,可以从依赖表(StudentClass, etc.)中删除记录,然后删除'Classes'记录,但我需要保存数据。
我找到了解决方案,在所有被其他表引用的表中,我创建了列'IsDeleted'。这意味着如果我想从'Classes'表中删除记录,我只需将'IsDeleted'列更新为1。要向用户显示,我使用"SELECT * .... FROM ... WHERE Classes.IsDeleted = 0".
这是我的解决办法!你能告诉我,你如何解决这些问题,与我分享你的方法,请!任何意见对我来说都是有趣的!谢谢您的回复!
编辑:
还有其他解决办法吗?
发布于 2013-04-08 18:08:29
非常经典的问题,我看到您的解决方案实现了很多很多次。通常情况下,它被称为“软”删除,因为您仍然拥有数据库中的数据,但它不会出现在UI中。
有两个潜在的缺点浮现在脑海中:
缓解这两个问题的一个潜在解决方案是不时运行一项作业,将已删除的数据存档/移动到其他地方。如果需要,可以随时查询或恢复它,但它不会影响其他“活动”记录。
https://stackoverflow.com/questions/15876019
复制相似问题