Django 迁移中会删除数据的危险命令

Django 迁移中会删除数据的危险命令及操作

在 Django 迁移系统中,以下命令和操作会直接或间接删除数据库表数据,属于高风险操作,在生产环境中必须谨慎使用:

1. 会删除数据的迁移命令

直接删除数据的命令

  • migrate zero (回滚所有迁移)

    bash 复制代码
    python manage.py migrate app_name zero

    → 会删除指定应用的所有表及其数据(按迁移反向操作)

  • flush (清空数据库)

    bash 复制代码
    python manage.py flush

    → 删除所有表中的所有数据(保留表结构)

危险组合命令

  • reset_db (Django-extensions 提供)

    bash 复制代码
    python manage.py reset_db

    → 完全重置数据库(删除所有表和数据)

安全操作建议

  1. 必须执行的预防措施

    bash 复制代码
    # 执行前先备份数据库
    python manage.py dumpdata > backup.json
    # 或使用数据库原生工具
    pg_dump mydb > backup.sql
  2. 替代方案

    • 使用软删除(添加 is_deleted 字段)而非物理删除
    • 先归档数据再执行删除操作
    • 使用 db_table 重命名而非删除表
  3. 检查迁移影响

    bash 复制代码
    # 查看将执行的SQL(不实际执行)
    python manage.py sqlmigrate app_name migration_number
    
    # 查看迁移计划
    python manage.py migrate --plan
  4. 生产环境操作流程

    1. 在测试环境验证迁移
    2. 备份生产数据库
    3. 在维护窗口期执行
    4. 准备回滚方案
    5. 监控执行过程

重要提醒:任何包含 DeleteModelRemoveFieldRunPython/RunSQL 中有删除操作的迁移文件,都应视为高风险迁移,必须经过严格审查才能在生产环境执行。

相关推荐
苍煜18 小时前
慢SQL优化实战教学
java·数据库·sql
zhaoyong22219 小时前
MySQL 存储过程中字符集与排序规则不匹配导致查询性能下降的解决方案
jvm·数据库·python
sinat_3834373619 小时前
golang如何从Python转型Go开发_golang从Python转型Go开发攻略
jvm·数据库·python
远洪19 小时前
claude code 国内安装使用
数据库·mysql
雨辰AI19 小时前
SpringBoot3 + 人大金仓 V9 微服务监控实战|Prometheus+Grafana+SkyWalking 全链路监控
数据库·后端·微服务·grafana·prometheus·skywalking
二哈赛车手19 小时前
新人笔记---ES和kibana启动问题以及一些常用的linux的错误排查方法,以及ES,数据库泄密解决方案[超详细]
java·linux·数据库·spring boot·笔记·elasticsearch
myrh pdmd19 小时前
maven导入spring框架
数据库·spring·maven
爬山算法19 小时前
MongoDB(118)如何在升级过程中进行数据备份?
数据库·mongodb·oracle
Muyuan199820 小时前
28.Paper RAG Agent 开发记录:修复 LLM Rerank 的解析、Fallback 与可验证性
linux·人工智能·windows·python·django·fastapi
千月落20 小时前
Redis数据迁移
数据库·redis·缓存