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作为主键。

posted @ 2019-08-15 17:34  一只小麻瓜  阅读(389)  评论(0编辑  收藏  举报