默认情况下,配置的数据库是 SQLite,这里使用的就是这个默认的内嵌数据库,不需要另外设置。当然也可以使用mysql之类其他的数据库,具体操作见:https://django-intro-zh.readthedocs.io/zh_CN/latest/part2/#_1
使用额外的元数据来定义你的模型 —— 本质上是你的数据库布局。编辑 polls/models.py 文件:
注释——polls文件夹的由来:
首先,这是一个用来投票的应用。
处于 manage.py 所在的目录下时,运行这行命令来创建一个应用:
python manage.py startapp polls
这将会创建一个 polls 目录,它的目录结构大致如下:
polls/ __init__.py admin.py migrations/ __init__.py models.py tests.py views.py
这个目录结构包括了投票应用的全部内容。
现在回到正题;我们要使用额外的元数据来定义模型,编辑 polls/models.py 文件:
from django.db import models
class Question(models.Model):
question_text = models.CharField(max_length=200)
pub_date = models.DateTimeField('date published')
class Choice(models.Model):
question = models.ForeignKey(Question, on_delete=models.CASCADE)
choice_text = models.CharField(max_length=200)
votes = models.IntegerField(default=0)
代码非常直白。每个模型都被表示为 django.db.models.Model 类的子类。每个模型都有些类变量,每一个都表示为模型里的一个数据库字段。
注释——python的继承:
class name(object): #your code pass
pass用作占位符,有代码时不用写。name是新建的类名,object是父类的类名。
每个字段都是 Field 类的实例 - 比如,字符字段被表示为 CharField,日期时间字段被表示为 DateTimeField。这告诉 Django 每个要处理的字段是什么数据类型。
使用了 ForeignKey 外键来定义一个关系。这会告诉 Django 每个 Choice 对象都和一个 Question 对象相关联。Django 支持所有常用的数据库关系:多对一、多对多和一对一。
要在项目中包含应用,我们需要在 INSTALLED_APPS 设置里添加这个应用的设置类。这个设置类 PollsConfig 在 polls/apps.py 文件里。编辑 mysite/settings.py,然后在 INSTALLED_APPS 设置里添加这个点分路径,使其包含字符串 polls。
将代码添加一行,改成这个样:
# mysite/settings.py
INSTALLED_APPS = [
'polls.apps.PollsConfig',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
]
接着回到cmd界面,运行以下的命令:
python manage.py makemigrations polls
通过运行 makemigrations 命令,你告诉了 Django 你对模型文件做了些修改(在上面例子,你创建了新的模型),修改的部分被储存为了一次 迁移
紧接着下一步:Django 有一个自动执行数据库迁移并同步管理你的数据库结构的命令 - 这个命令是 migrate,我们马上就会接触它 - 但是首先,让我们看看迁移命令会执行哪些 SQL 语句。sqlmigrate 命令接收一个迁移的名称,然后返回对应的 SQL:
python manage.py sqlmigrate polls 0001
这时,激活模型就结束了。
注释——激活模型:
迁移是非常强大的功能,它能让你在开发过程中持续的改变数据库结构而不需要重新删除和创建表 - 它专注于使数据库平滑升级而不会丢失数据。我们会在后面的教程中更加深入的学习这部分内容,现在,你只需要记住,改变模型需要这三步:
- 编辑 models.py 文件,改变模型。
- 运行 python manage.py makemigrations 为模型的改变生成迁移文件。
- 运行 python manage.py migrate 来应用数据库迁移
首先,我们得创建一个能登录管理页面的用户。请运行下面的命令:
python manage.py createsuperuser
输入你想使用的用户名,然后回车。
Username: admin
接着,你会被提示要求输入邮箱:
Email address: [email protected]
最后一步是输入密码。你会被要求输入两次密码,第二次的目的是为了确认第一次输入的确实是你想要的密码。
Password: ********
Password(again): ********
Superuser created successfully.
在cmd界面下键入:
python manage.py runserver 0.0.0.0:8000
前面的python manage.py runserer是服务器运行的命令,而后面的0.0.0.0是允许所有字段IP的设备接入,端口号是8000,防止使用8080发生冲突。
在;浏览里键入: 域名:8000/admin
域名是你的电脑的ip地址,也是连接至你电脑的路由器出接口的IP地址,可以在cmd中用ipconfig命令查看ipv4地址这一选项。
其他局域网内的设备也可以按这样的方式连接,如图:
END