关于数据逻辑删除的问题?

发布于 2022-09-02 09:53:29 字数 85 浏览 26 评论 0

我在表中逻辑删除了一条数据,表中存在唯一索引的字段,逻辑删除后,我有要insert一条一样的数据,这样肯定不行,如何解决这个问题?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

來不及說愛妳 2022-09-09 09:53:29

1.如1L所言,取消唯一约束,靠程序控制;
2.如果是mysql的话,可以在insert语句后面加上on duplicate key update status = ?
3.同样是mysql的情况下,也可以用replace into代替insert into;

关于这个问题其实还有很大的思考空间,最灵活的方法是1,但同样要面临产生脏数据的风险(脏数据对程序代码的影响就不多说了,处理过的都懂的);2、3理论上只能保存最近一次逻辑删除的记录

采用哪种方法视乎业务上对逻辑删除数据保存要求,如果要保留历史数据而又不想采用方法1的话,可以在2、3基础上实时(代码层面)或定时对逻辑删除的数据迁移至历史表。

以上是本人知道的方法,如果还有更好的方法,希望不吝赐教。

开始看清了 2022-09-09 09:53:29

最简单的办法就是取消唯一索引, 用程序来控制保证该字段唯一。

稳稳的幸福 2022-09-09 09:53:29

数据完全一样(注意是完全一样,修改时间之类的也一样)的话,你恢复删除就好了啊

如果数据不完全一样,要么换个id再插入一遍,要么加一列做修改历史

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文