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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值