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: 应用迁移,对数据库进行实际的更改,使其与当前的模型保持一致。
相关推荐
ytttr87311 分钟前
MATLAB基于LDA的人脸识别算法实现(ORL数据库)
数据库·算法·matlab
云老大TG:@yunlaoda3601 小时前
如何进行华为云国际站代理商跨Region适配?
大数据·数据库·华为云·负载均衡
思成不止于此1 小时前
【MySQL 零基础入门】事务精讲(二):ACID 特性与并发问题
数据库·笔记·学习·mysql
Boilermaker19921 小时前
[MySQL] 初识 MySQL 与 SQL 基础
数据库·mysql
今晚务必早点睡1 小时前
Redis——快速入门第二课:Redis 常用命令 + 能解决实际问题
数据库·redis·bootstrap
Hello.Reader2 小时前
Flink SQL Materialized Table 语句CREATE / ALTER / DROP介绍
数据库·sql·flink
Boilermaker19922 小时前
[MySQL] 服务器架构
数据库·mysql·架构
云老大TG:@yunlaoda3602 小时前
如何通过华为云国际站代理商CSBS进行备份策略设置?
运维·数据库·华为云
一 乐2 小时前
酒店预约|基于springboot + vue酒店预约系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
NineData3 小时前
NineData第三届数据库编程大赛:用一条SQL解数独问题
数据库·云计算·ai编程