Django 学习笔记 1.2 模型和 admin 站点

文章目录

    • 前言
    • 1 数据库
    • 2 创建模型
    • 3 激活模型
      • 3.1 让工程包含应用
      • 3.2 运行 makemigrations 为模型的改变生成迁移文件
      • 3.3 运行 migrate 命令来应用数据库的迁移
      • 3.4 小结
    • 4 初试 API
    • 5 介绍 Django 管理页面
      • 5.1 创建一个管理员账号
      • 5.2 启动开发服务器
      • 5.3 进入管理站点页面
      • 5.4 向管理页面中加入投票应用
      • 5.5 体验便捷的管理功能
    • END

前言

https://docs.djangoproject.com/zh-hans/2.2/intro/tutorial02/

在这节里,我们将建立数据库,创建第一个模型,关注 Django 提供的自动生成的管理页面。换句话说,就是在进行数据库相关的操作,模型是数据库的基础结构,管理页面又是对数据库进行可视化的操作。

1 数据库

打开 mysite/settings.py 。这是个包含了 Django 项目设置的 Python 模块。

通常,这个配置文件使用 SQLite 作为默认数据库。如果你不熟悉数据库,或者只是想尝试下 Django,这是最简单的选择。Python 内置 SQLite,所以你无需安装额外东西来使用它。

2 创建模型

在 Django 里写一个数据库驱动的 Web 应用的第一步是定义模型 - 也就是数据库结构设计和附加的其它元数据。

在这个简单的投票应用中,需要创建两个模型:问题 Question 和选项 Choice。Question 模型包括问题描述和发布时间。Choice 模型有两个字段,选项描述和当前得票数。每个选项属于一个问题。

这些概念可以通过一个简单的 Python 类来描述。按照下面的例子来编辑 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 类的子类。每个模型有一些类变量,它们都表示模型里的一个数据库字段。

3 激活模型

上面的一小段用于创建模型的代码给了 Django 很多信息,通过这些信息,Django 可以:

  • 为这个应用创建数据库 schema(生成 CREATE TABLE 语句)。
  • 创建可以与 Question 和 Choice 对象进行交互的 Python 数据库 API。

3.1 让工程包含应用

为了在我们的工程中包含这个应用,我们需要在配置类 INSTALLED_APPS 中添加设置:

INSTALLED_APPS = [
    'polls.apps.PollsConfig',
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

3.2 运行 makemigrations 为模型的改变生成迁移文件

>python manage.py makemigrations polls
Migrations for 'polls':
  polls\migrations\0001_initial.py
    - Create model Question
    - Create model Choice

迁移是 Django 对于模型定义(也就是你的数据库结构)的变化的储存形式。

3.3 运行 migrate 命令来应用数据库的迁移

Django 有一个自动执行数据库迁移并同步管理你的数据库结构的命令 - 这个命令是 migrate。

这个 migrate 命令选中所有还没有执行过的迁移(Django 通过在数据库中创建一个特殊的表 django_migrations 来跟踪执行过哪些迁移)并应用在数据库上 - 也就是将你对模型的更改同步到数据库结构上。

迁移是非常强大的功能,它能让你在开发过程中持续的改变数据库结构而不需要重新删除和创建表 - 它专注于使数据库平滑升级而不会丢失数据。

3.4 小结

简单来说,改变模型需要这三步:

  • 编辑 models.py 文件,改变模型。
  • 运行 python manage.py makemigrations 为模型的改变生成迁移文件。
  • 运行 python manage.py migrate 来应用数据库迁移。

4 初试 API

一旦创建 数据模型 后,Django 自动给予你一套数据库抽象 API,允许你创建,检索,更新和删除对象。

现在让我们进入交互式 Python 命令行,尝试一下 Django 为你创建的各种 API。通过以下命令打开 Python 命令行:

$ python manage.py shell

5 介绍 Django 管理页面

5.1 创建一个管理员账号

python manage.py createsuperuser

5.2 启动开发服务器

python manage.py runserver

5.3 进入管理站点页面

你将会看到几种可编辑的内容:组和用户。它们是由 django.contrib.auth 提供的,这是 Django 开发的认证框架。

5.4 向管理页面中加入投票应用

python manage.py runserver

5.5 体验便捷的管理功能

END


你可能感兴趣的:(应用,-,WEB应用)