如何解决不小心删除了 Django 项目中的数据库表如何重新进行迁移?
我不小心从数据库中删除了一个表(模型 AboutUs)。 通常我会删除这次迁移的 djando.migrations 记录(0063),删除迁移文件并运行 makemigrations 和 migrate 命令。
- 第一个问题是,在有问题的迁移(0063)之后大约有 20 次迁移,其中有为同一模型修改、添加、删除的字段
- 第二个问题是我不是一个人在做这个项目,它在 GitHub 中共享。如果我删除迁移文件,则会与原始数据库发生冲突
有没有办法运行只与特定模型相关的迁移?
还有其他解决方法的想法吗?
解决方法
对于一次性解决方案,您可以将数据库中涉及此表的所有迁移操作复制到新的迁移(不必编号),将所有其他迁移从迁移目录中移出并运行这种迁移本身。成功后,您可以删除此迁移,将其从 django_migrations
表中删除并恢复之前的迁移。
要创建此临时迁移,您只需复制初始迁移,省略 operations
列表的内容。要填充操作,您必须完成现有的迁移并复制相关操作。
为了将来,您可以通过在任何手动数据库操作之前进行数据库备份来保护自己。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。