makemigrations和migrate到底干了什么以及如何查询原生的sql语句

在你改动了 model.py的内容之后执行下面的命令:

python manger.py makemigrations

相当于 在该app下的 migrations目录,并记录下你所有的关于modes.py的改动,比如0001_initial.py, 但是这个改动还没有作用到数据库文件

可以在项目的migrations目录手动打开这个文件,看看里面是什么

 

在此之后执行命令

python manager.py migrate

将该改动作用到数据库文件,比如产生table之类

D:\PycharmProjects\DemoDjango>python manage.py makemigrations   
Migrations for 'webAppOne':
  webAppOne\migrations\0002_companyinfo.py  #  在migrations目录,并记录下你所有的关于modes.py的改动,没有作用到数据库
    - Create model CompanyInfo

D:\PycharmProjects\DemoDjango>python manage.py migrate  # 作用到数据库,创建表
Operations to perform:
  Apply all migrations: admin, auth, contenttypes, sessions, webAppOne
Running migrations:
  Applying webAppOne.0002_companyinfo... OK

D:\PycharmProjects\DemoDjango>

 

当makemigrations之后会在项目的migrations目录产生了0001_initial.py 文件,可以查看下该migrations会对应的SQL命令

python manage.py sqlmigrate webAppOne  0001

D:\PycharmProjects\DemoDjango>python manage.py sqlmigrate webAppOne 0001
BEGIN;
--
-- Create model Userinfo
--
CREATE TABLE "webAppOne_userinfo" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "username" varchar(32) NOT NULL, "password" varchar(32) NOT NULL, "salary" integer NOT NULL
);
COMMIT;

D:\PycharmProjects\DemoDjango>

 

表名组成结构为:应用名_类名(如:webAppOne_userinfo)。

注意:尽管我们没有在models给表设置主键,但是Django会自动添加一个id作为主键。

转载于:https://www.cnblogs.com/chenpengzi/p/11359423.html

makemigrations和migrate是Django中的两个相关但不同的命令。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* [Django的MigrateMakemigrations讲解](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* [django中migratemakemigrations 区别](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 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值