Django 中数据库迁移命令

在 Django 中,python manage.py makemigrationspython manage.py sqlmigrate polls 0003python manage.py migrate 是与数据库迁移相关的重要命令。它们的作用和对应内容如下:

1. python manage.py makemigrations

  • 功能 :
    • 此命令会根据你的模型文件 (models.py) 中的变化生成新的迁移文件。这些迁移文件是 Python 脚本,用于描述如何将数据库的结构与相应的 Django 模型同步。
  • 对应内容 :
    • 如果你对模型进行了更改(例如添加了字段或修改了字段的类型),运行此命令后会创建一个新的迁移文件,该文件存储在应用的 migrations 文件夹中。它包含了必要的指令,以便可以执行这些更改。

2. python manage.py sqlmigrate polls 0003

  • 功能 :
    • 此命令将输出给定迁移(例如 0003)对应的 SQL 语句,而不会实际执行迁移。它用于查看 Django 将要在数据库上执行的原始 SQL 操作,非常有用来调试和理解迁移行为。
  • 对应内容 :
    • polls 是应用名称,0003 是迁移文件的编号。例如,如果你在 polls/migrations/0003_auto_20231001_1200.py 定义了迁移,这个命令将显示该迁移所采取的所有操作的 SQL 语句,例如创建表、删除字段或添加索引等。

3. python manage.py migrate

  • 功能 :
    • 此命令会应用迁移到数据库。它将检查哪些迁移尚未应用,并在数据库中执行必要的操作,从而将数据库状态更新为与模型文件一致。
  • 对应内容 :
    • 执行此命令之后,Django 会根据之前生成的迁移文件,对数据库进行修改(如创建表、添加字段、修改现有字段等)。当迁移成功后,Django 在 django_migrations 表中记录已应用的迁移信息。

总结

  • makemigrations: 创建新的迁移文件,捕获模型的更改。
  • sqlmigrate: 查看特定迁移将执行的 SQL 语句,不做实际修改。
  • migrate: 应用迁移,对数据库进行实际的更改,使其与当前的模型保持一致。
相关推荐
凡人的AI工具箱8 分钟前
每天40分玩转Django:Django Celery
数据库·后端·python·django·sqlite
心之语歌1 小时前
LiteFlow 流程引擎引入Spring boot项目集成pg数据库
数据库·spring boot·后端
qq_356408661 小时前
clickhouse query_log 常用查询语句
数据库·clickhouse
小屁不止是运维2 小时前
麒麟操作系统服务架构保姆级教程(八)数据库拆分静态业务拆分和负载均衡
运维·服务器·数据库·架构·负载均衡
凡人的AI工具箱2 小时前
每天40分玩转Django:Django性能优化
后端·python·性能优化·django·sqlite
凡人的AI工具箱2 小时前
每天40分玩转Django:Django即时聊天应用实战
数据库·人工智能·后端·python·django·sqlite
BUG研究员_2 小时前
微服务のGeteWay
java·数据库·微服务
ice___Cpu2 小时前
Redis - 8 ( 10000 字 Redis 入门级教程 )
数据库·redis·缓存
Rk..2 小时前
数据库索引相关总结
java·数据库·sql
菠菠萝宝2 小时前
【Go学习】-01-4-项目管理及协程
数据库·学习·golang·操作系统·软件工程·协程·os