作者:zy一生的最爱_149 | 来源:互联网 | 2023-09-24 08:02
在你改动了model.py的内容之后执行下面的命令:pythonmanger.pymakemigrations相当于在该app下的migrations目录,并记录下你所有的关于mo
在你改动了 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\migrationsD:\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>02_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作为主键。