V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
mmdsun
V2EX  ›  问与答

如何处理修改而不影响其他关联数据数据?

  •  
  •   mmdsun · 2021-01-19 13:03:50 +08:00 via Android · 1009 次点击
    这是一个创建于 1404 天前的主题,其中的信息可能已经有所发展或是发生改变。

    比如有表:order 订单----address 地址表,下单时订单表存有地址表 id,地址信息添加后不能修改。

    现在在下新订单时,除了可以选择以前保存的地址,还可以对地址进行编辑修改。由于之前的订单也引用了同样的地址 ID,导致历史的订单中显示的地址信息也发生了变化。

    像这种情况大家是什么处理的呢?

    3 条回复    2021-01-19 13:26:51 +08:00
    mmdsun
        1
    mmdsun  
    OP
       2021-01-19 13:18:18 +08:00 via Android
    这算是范式高的弊端么。

    随着范式级别越高,存储同样的数据就需要分解成更多张表,并通过 id 关联。
    这种修改问题处理起来就很麻烦。。
    vermouth1995
        2
    vermouth1995  
       2021-01-19 13:18:42 +08:00
    数据冗余?
    mmdsun
        3
    mmdsun  
    OP
       2021-01-19 13:26:51 +08:00 via Android
    @vermouth1995
    差不多吧。蹲个更好的解决方法。

    通用解决方法是 删除=软删除。
    修改=软删除旧+新增
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2647 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 04:21 · PVG 12:21 · LAX 20:21 · JFK 23:21
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.