Django makemigrations 和 migrate 作用详解

本文详细介绍了Django项目中数据库模型变更的过程,包括如何通过makemigrations生成DDL语句,以及如何通过migrate命令将变更应用到数据库中。此外,还讲解了如何查看和管理这些迁移文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

开始接触Django编程,用来写后端代码。后端必然需要和数据库打交道,在Django中对于数据库模型一般写在models.py文件中。

当写好之后,需要在setting文件中配置 引入'api.apps.ApiConfig' 。

然后在运行之前需要做两件事:

1. python3 manage.py makemigrations 

makemigrations的作用是Django会去检查创建或修改数据库,如果不合法会给出提示。

当第一次执行该操作,会在app下面创建migrations目录,并创建0001_inital.py文件,文件中记录了当前的建表、依赖等信息。

当下一次执行该操作,如果有关于model.py改动,会在migrations下生成已修改内容为名,类似0002_alter_permission_name_max_length.py的文件,文件中记录了你修改字段等信息。如果没有改动则提示:No changes detected。需要注意的是,此时这些改动还并没有被真正执行,迁移到数据库中!
 

我们可以使用 ‘python3 manage.py sqlmigrate appname xxx’ 去查看执行的sql语句,例如:

python3 manage.py sqlmigrate api 0001

从截图中可以看出,创建了一个名为api_userinfo的表,有三个字段。

 

可以使用python3 manage.py showmigrations 去查看当前项目所有的app及对应的已经生效的migration文件,其中[x]表示migrte通过,[]表示未通过 。如下所示,我的api项目里的initial通过。注意:[]migration文件未通过的,可以通过删除migrations下对应名称文件撤销这次更新。

 

2. python manage.py migrate

执行完makemigrations只是生成了对应的sql语句,还并没真正将改动迁移到数据库中。需要执行migrate才能将改动迁移到数据库,完成建表、修改字段等操作。

 

所以综上所述,makemigrations生成ddl(数据库模式定义语言),migrate真正地去执行ddl。

 

参考资料:

1. https://blog.csdn.net/weixin_33127753/article/details/90717038

makemigrationsmigrateDjango中的两个相关但不同的命令。makemigrations命令用于创建数据库迁移文件,当你在Django中修改了模型的结构时,需要运行makemigrations命令来生成一个包含这些修改的迁移文件。迁移文件包含了数据库模式的变化,包括创建、修改或删除表、添加或删除字段等。而migrate命令用于执行数据库迁移,即将模型的变化应用到数据库中的过程。当你运行migrate命令时,Django会检查迁移文件,并将其中的变化应用到数据库中,确保数据库的结构与模型的结构保持一致。简而言之,makemigrations用于生成数据库迁移文件,而migrate用于将迁移文件应用到数据库中。makemigrations是一个生成迁移文件的过程,而migrate是一个执行迁移文件的过程。如果想指定某个migrations文件,可以使用命令python manage.py migrate \[app_label\] \[migration_name\],例如python manage.py migrate cases 0011_auto_20220726_1440。\[2\]\[3\] #### 引用[.reference_title] - *1* *3* [DjangoMigrateMakemigrations讲解](https://blog.csdn.net/momoda118/article/details/120181669)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [djangomigratemakemigrations 区别](https://blog.csdn.net/yuanhou110/article/details/131455342)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值