fkbd
V2EX  ›  问与答

Laravel 使用 ORM 时,如何记录 update 前的数据比较合理呢?

  •  
  •   fkbd · Oct 12, 2017 · 2644 views
    This topic created in 3134 days ago, the information mentioned may be changed or developed.
    我现在有两个想法
    1.单独建立一个数据库用于保存被更新前的数据,但是实施起来操作比较繁琐。
    2.在原有数据库中新增一列版本号,同时把旧数据使用软删除删除。在这种方法中,我发现需要处理自增主键冲突。
    我现在的办法是取消自增主键但又怕取消后会带来很多意料之外的问题。

    特来寻求更优的解决方案。
    2 replies    2017-10-13 08:40:32 +08:00
    Outhwaite
        1
    Outhwaite  
       Oct 12, 2017
    我的做法是建快照表,和原先的表结构一样,然后增加一个保存时间字段。每次更新先保存一份记录在快照表。应该跟第一个方法差不多吧。。
    msg7086
        2
    msg7086  
       Oct 13, 2017
    另开一个 journal 表吧。主表里原地加数据会影响这个表本身的性能,不如单开一个,反正存档用,一来数据损坏也不要紧,二来查询时不会影响主表的性能。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   6233 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 35ms · UTC 06:14 · PVG 14:14 · LAX 23:14 · JFK 02:14
    ♥ Do have faith in what you're doing.