Django之第一个app<5>
来源:互联网 发布:软件运营方案 编辑:程序博客网 时间:2024/05/16 06:20
激活模型
上一篇短小的模型代码告诉Django许多信息。有了它,Django能够做:
- 为这个应用创建一个数据库模式(
CREATE TABLE statements
) - 创建一个python类型的获取
Question
和Choice
模型对象的API
但是,首先我们需要告诉工程,polls这个应用被安装了。
注意:Django应用时可插入的,你可以在多个工程中使用一个应用,你可以传播应用,因为它们不必与一个Django安装器绑定。
再次编辑mysite/setting.py
这个文件,改变一个INSTALLEND_APPS
这个设置,要包含字符串polls
INSTALLED_APPS = ( 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'polls',)
现在,Django知道了要包含polls这个app。让我们来运行另一个命令。
$ python manage.py makemigrations polls
你会看到类似与下面的信息:
Migrations for 'polls': 0001_initial.py: - Create model Choice - Create model Question - Add field question to choice
通过运行makemigrations
这个命令,你告诉Django你已经对你的模型做出了一些改动,并且你想要这些改动被存储。
Migrations是Django实现存储模型变化的原理,它们只是磁盘上的文件。如果你想要阅读migration的话,请打开polls/migration/0001_initial.py
。当然这个文件是可以手动编辑的。
migrate
这个命令会运行migrations和自动管理你的数据库模式。首先我们来看一下migration会运行什么样的SQL语句。sqlmigrate
命令返回执行了什么样的SQL语句
$ python manage.py sqlmigrate polls 0001
你可以看到类似与下面的信息:
BEGIN;CREATE TABLE "polls_choice" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "choice_text" varchar(200) NOT NULL, "votes" integer NOT NULL);CREATE TABLE "polls_question" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "question_text" varchar(200) NOT NULL, "pub_date" datetime NOT NULL);CREATE TABLE "polls_choice__new" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "choice_text" varchar(200) NOT NULL, "votes" integer NOT NULL, "question_id" integer NOT NULL REFERENCES "polls_question" ("id"));INSERT INTO "polls_choice__new" ("choice_text", "votes", "id", "question_id") SELECT "choice_text", "votes", "id", NULL FROM "polls_choice";DROP TABLE "polls_choice";ALTER TABLE "polls_choice__new" RENAME TO "polls_choice";CREATE INDEX "polls_choice_7aa0f6ee" ON "polls_choice" ("question_id");COMMIT;
注意:
- 输出的信息取决于你使用的数据库,官方的例子是使用PostgreSQL,我是使用SQLite。
- 所创建数据表的名称是自动产生的,是应用的名称(这里是polls)加上模型名字的小写(比如,question和choice)
- 主键(Primary Keys)会被自动创建
- 按照约定,Django会在外键名后面加上
_id
如果你感兴趣的话,你也可以运行python manage.py check
这个命令。这只会检查你的工程是否有问题,而不会做migrations和创建数据库。
现在,运行migrate
这个命令来在你的数据库中创建这些模型数据表
charies:mysite weichuang$ python manage.py migrateOperations to perform: Synchronize unmigrated apps: staticfiles, messages Apply all migrations: admin, contenttypes, polls, auth, sessionsSynchronizing apps without migrations: Creating tables... Running deferred SQL... Installing custom SQL...Running migrations: Rendering model states... DONE Applying polls.0001_initial... OK
记住:migrate
这个命令会执行所有还没有应用的migrations(Django会使用一个在数据库中特殊的数据表来跟踪哪些被应用,这个数据表叫做django_migrations
)。
Migrations非常强大,允许你在开发工程的过程中随时改变你的模型,而不用删除已经存在的数据库或者数据表和重新创建新的。Migrations擅长更新你的数据库,而不会失去数据。记住模型改变的三个步骤:
- 在
models.py
改变你的模型 - 运行
python manage.py migrate
来创建这些变化的migrations - 运行
python manage.py migrate
来应用数据库的变化
创建和应用migrations的命令分开的原因是你会将migrations提交到你的帮本控制系统。
- Django之第一个app<5>
- Django之第一个app<1>
- Django之第一个app<2>
- Django之第一个app<3>
- Django之第一个app<4>
- Django之第一个app<6>
- Django之第一个app<7>
- Django之第一个app<8>
- Django之第一个app<9>
- Django之第一个app<10>
- Django之第一个app<11>
- Django之第一个app<12>
- Django之第一个app<13>
- Django之第一个app<14>
- Django之第一个app<15>
- Django之第一个app<16>
- Django之第一个app<17>
- Django之第一个app<18>
- java.lang.IllegalStateException: Target host must not be null, or set in parameters. scheme=null, ho
- c语言之函数或者变量的weak属性
- 将ppt格式转换为pdf格式
- 【论坛】游戏开发大板上线公告
- hdoj 1050 Moving Tables
- Django之第一个app<5>
- [Android]简单的在线翻译应用
- 1038. Recover the Smallest Number (30)好题
- maven 工程 dubbo服务的xml配置文件报错的问题
- iOS AutoLayout自动布局中级开发教程(5)-修改约束的值,延迟加载
- jstree父节点与子节点操作互不影响
- java动态代理详解
- 详解JBOSS系列一(利用JNDI,EJB远程调用本地的Bean)
- 常用SQL语句收藏 <二>