Django创建应用程序
需要2.1.5版本以上,不然会报错no such table: main.auth_user__old
在前面查看项目时终端窗口还运行着runserver,再打开一个终端窗口,切换到manage.py目录,激活虚拟环境,执行startapp
python manage.py startapp learning_logs
项目目录新增了一个learning_logs的文件夹
定义模型
models.py中定义在应用程序中管理的数据
from django.db import models
# Create your models here.
class Topic(models.Model):
#用户学习主题
topic=models.CharField(max_length=200)
#自动设置当前的日期和时间
date_added=models.DateTimeField(auto_now_add=True)
def __str__(self):
return self.text
激活模型
在setting.py文件中进行修改
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
#my apps
'learning_logs',
]
让Django修改数据库,使用makemigrations命令
python manage.py makemigrations learning_logs
Django创建了一个迁移文件
应用迁移
python manage.py migrate
切记,每次修改models之后都要采取下面三个步骤:修改,对learning_logs调用makemigratations,迁移项目
管理网站
创建超级用户
python manage.py createsuperuser
向管理网站注册模型
修改admin.py
from django.contrib import admin
# Register your models here.
from learning_logs.models import Topic
admin.site.register(Topic)
使用超级用户账户访问管理网站 http://127.0.0.1:8000/admin/
添加几个主题
定义模型Entry
#建立一对多关系
#delete=models.CASCADE
# 主外关系键中,级联删除,也就是当删除主表的数据时候从表中的数据也随着一起删除
class Entry(models.Model):
topic=models.ForeignKey(Topic,on_delete=models.CASCADE)
text=models.TextField()
date_added = models.DateTimeField(auto_now_add=True)
class Meta:
#指定模型的复数形式
verbose_name_plural='entries'
def __str__(self):
return self.text[:50]+"..."
修改models.py之后不要忘记再次迁移数据库
python manage.py makemigrations learning_logs
python manage.py migrate
向管理网站注册Entry
修改admin.py
from django.contrib import admin
# Register your models here.
from learning_logs.models import Topic,Entry
admin.site.register(Topic)
admin.site.register(Entry)
查看之前的网页在learning_logs下面多出了Entries
添加完之后
shell
启动一个python解释器探索数据库中的数据
Topic.objects.all()
```python
>>> topics=Topic.objects.all()
>>> for topic in topics:
... print(topic.id,topic)
使用相关模型的小写名称,下划线和单词set来通过外键关系访问数据
>>> t.entry_set.all()
<QuerySet [<Entry: The opening is the first part of the game,roughly...>]>
>>>