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: 应用迁移,对数据库进行实际的更改,使其与当前的模型保持一致。
相关推荐
卤炖阑尾炎1 小时前
基于 MySQL 主主复制 + HAProxy+Keepalived 构建高可用集群实战
数据库·mysql
Dxy12393102161 小时前
MySQL 如何高效删除大量数据:策略与最佳实践
数据库·mysql·oracle
倔强的石头_2 小时前
从 “不得不存” 到 “战略必争”:工业数据的价值觉醒之路
数据库
倔强的石头_2 小时前
新型电力系统应该用什么数据库?——时序数据库选型与落地实战
数据库
南汐以墨3 小时前
一个另类的数据库-Redis
数据库·redis·缓存
RInk7oBjo3 小时前
spring-事务管理
数据库·sql·spring
希望永不加班3 小时前
SpringBoot 数据库连接池配置(HikariCP)最佳实践
java·数据库·spring boot·后端·spring
黑牛儿4 小时前
MySQL 索引实战详解:从创建到优化,彻底解决查询慢问题
服务器·数据库·后端·mysql
捧月华如4 小时前
RAG 入门-向量存储与企业级向量数据库 milvus
数据库·milvus
杨云龙UP5 小时前
Oracle Data Pump实战:expdp/impdp常用参数与导入导出命令整理_20260406
linux·运维·服务器·数据库·oracle