Django 初试水(二)
这部分链接上一部分。将建立数据库,创建第一个模型,并主要关注 Django 提供的自动生成的管理页面。
打开 mysite/setting.py 文件。这包含了 Django 项目设置的 Python 模块。通常,这个配置文件使用 SQLite 作为默认的数据库。
在此,我只是作为试水,不打算切换数据库。当然有需要的,可以自己去使用一些更具扩展性的数据库,例如 PostgreSQL 等。
如果你想使用其他数据库,你需要安装合适的 database bindings ,然后改变设置文件中 DATABASES 'default' 项目中的一些键值:
- ENGINE-- 可选值有- 'django.db.backends.sqlite3',- 'django.db.backends.postgresql',- 'django.db.backends.mysql',
- 或 'django.db.backends.oracle'。其它 可用后端。
- NAME- 数据库的名称。如果使用的是 SQLite,数据库将是你电脑上的一个文件,在这种情况下,- NAME应该是此文件的绝对路径,包括文件名。默认值- os.path.join(BASE_DIR, 'db.sqlite3')将会把数据库文件储存在项目的根目录。
如果你不使用 SQLite,则必须添加一些额外设置,比如 USER 、 PASSWORD 、 HOST 等等。想了解更多数据库设置方面的内容,请看文档:DATABASES 。
首先创建模型
在 Django 里写一个数据库驱动的 web 应用第一步是定义模型,也就是数据库结构设计和附加的其他元数据。
修改 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的子类表示。 django.db.models.Model。每个模型都有许多类变量,每个类变量表示模型中的一个数据库字段
每个字段都是 Field 类的实例 - 比如,字符字段被表示为 CharField ,日期时间字段被表示为 DateTimeField 。这将告诉 Django 每个字段要处理的数据类型。
每个 Field 类实例变量的名字(例如 question_text 或 pub_date )也是字段名,所以最好使用对机器友好的格式。你将会在 Python 代码里使用它们,而数据库会将它们作为列名。
你可以使用可选的选项来为 Field 定义一个人类可读的名字。这个功能在很多 Django 内部组成部分中都被使用了,而且作为文档的一部分。如果某个字段没有提供此名称,
Django 将会使用对机器友好的名称,也就是变量名。在上面的例子中,我们只为 Question.pub_date 定义了对人类友好的名字。对于模型内的其它字段,它们的机器友好名也会被作为人类友好名使用。
定义某些 Field 类实例需要参数。例如 CharField 需要一个 max_length 参数。这个参数的用处不止于用来定义数据库结构,也用于验证数据,我们稍后将会看到这方面的内容。
Field 也能够接收多个可选参数;在上面的例子中:我们将 votes 的 default 也就是默认值,设为0。
注意在最后,我们使用 ForeignKey 定义了一个关系。这将告诉 Django,每个 Choice 对象都关联到一个 Question 对象。Django 支持所有常用的数据库关系:多对一、多对多和一对一。
激活模型
上面的一小段代码给了 Django 很多信息。通过这些信息, Django 为这个应用
1.创建数据库 schema
2.创建可以与 Question(问题)和Choice(选项)对象进行交互的 Python 数据库 API 。
首先,把应用 Polls 安装到项目。
需要在配置类  INSTALLED_APPS 中添加设置。因为应用的 PollsConfig 写在文件 pollsapps.py 中。那么路径:'polls.apps.PollsConfig'
在项目的 setting.py 文件中修改。修改后:
INSTALLED_APPS = [
'polls.apps.PollsConfig',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
]
接下来执行命令行:
# 通过运行 makemigrations 命令,Django 会检测你对模型文件的修改(在这种情况下,你已经取得了新的),并且把修改的部分储存为一次 迁移。
E:\work\py_dj\mysite>python manage.py makemigrations polls
Migrations for 'polls':
polls\migrations\0001_initial.py
- Create model Question
- Create model Choice # 查看脚本
E:\work\py_dj\mysite>python manage.py sqlmigrate polls 0001
BEGIN;
--
-- Create model Question
--
CREATE TABLE "polls_question" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "question_text" varchar(200) NOT NULL, "pub_date" datetime NOT NULL);
--
-- Create model Choice
--
CREATE TABLE "polls_choice" ("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") DEFERRABLE INITIALLY DEFERRED);
CREATE INDEX "polls_choice_question_id_c5b4b260" ON "polls_choice" ("question_id");
COMMIT; #自动执行数据库迁移并同步管理你的数据库结构的命令
E:\work\py_dj\mysite>python manage.py migrate
Operations to perform:
Apply all migrations: admin, auth, contenttypes, polls, sessions
Running migrations:
Applying contenttypes.0001_initial... OK
Applying auth.0001_initial... OK
Applying admin.0001_initial... OK
Applying admin.0002_logentry_remove_auto_add... OK
Applying admin.0003_logentry_add_action_flag_choices... OK
Applying contenttypes.0002_remove_content_type_name... OK
Applying auth.0002_alter_permission_name_max_length... OK
Applying auth.0003_alter_user_email_max_length... OK
Applying auth.0004_alter_user_username_opts... OK
Applying auth.0005_alter_user_last_login_null... OK
Applying auth.0006_require_contenttypes_0002... OK
Applying auth.0007_alter_validators_add_error_messages... OK
Applying auth.0008_alter_user_username_max_length... OK
Applying auth.0009_alter_user_last_name_max_length... OK
Applying auth.0010_alter_group_name_max_length... OK
Applying auth.0011_update_proxy_permissions... OK
Applying polls.0001_initial... OK
Applying sessions.0001_initial... OK
注意:migrate 是一个强大的功能,这里没有详细的介绍。大家可以自己去了解。只要记住一下几步:
改变模型需要这三步:
- 编辑 models.py文件,改变模型。
- 运行 python manage.py makemigrations为模型的改变生成迁移文件。
- 运行 python manage.py migrate来应用数据库迁移。
使用 python manage.py shell 命令测试 API 吧!
E:\work\py_dj\mysite>python manage.py shell
Python 3.7.4 (default, Aug 9 2019, 18:34:13) [MSC v.1915 64 bit (AMD64)]
Type 'copyright', 'credits' or 'license' for more information
IPython 7.8.0 -- An enhanced Interactive Python. Type '?' for help. In [1]: from polls.models import Choice,Question In [2]: Question.objects.all()
Out[2]: <QuerySet []> In [3]: from django.utils import timezone In [4]: q = Question(question_text = "What's new?",pub_date = timezone.now()) In [5]: q.save() In [6]: Question.objects.all()
Out[6]: <QuerySet [<Question: Question object (1)>]> In [7]: q.id
Out[7]: 1
更多的可以自己去尝试:https://docs.djangoproject.com/en/3.0/topics/db/queries/
介绍 Django 管理页面
创建管理员账号
#创建账号管理员命令
E:\work\py_dj\mysite>py manage.py createsuperuser
Username (leave blank to use 'joint'): sailor
Email address: sailor@explem.com
Password:
Password (again):
This password is too short. It must contain at least 8 characters.
This password is too common.
This password is entirely numeric.
Bypass password validation and create user anyway? [y/N]: y
Superuser created successfully.
这里用户名:sailor password:123456 . 密码安全提示,最后确认创建Y。
创建完毕启动服务:
python manage.py runserver
现在,打开浏览器,转到你本地域名的 "/admin/" 目录, -- 比如 "http://127.0.0.1:8000/admin/" 。你应该会看见管理员登录界面:

登录

添加自己的应用
修改 polls/admin.py 注册应用
from django.contrib import admin from .models import Question admin.site.register(Question)
刷新页面,开始便捷的可视化操作。



Django 初试水(二)的更多相关文章
- Django 初试水(三)
		在前面的一和二中,分别实现了一些基础的操作,数据库和 Django 自带的管理界面,接下来,主要是创建我们自己的界面(视图). 访问一个地址,对应的服务器直接返回一个视图.这是最常见的交互. 就好比访 ... 
- Django 初试水(一)
		2020年注定是一个不平凡的一年!坚持就是胜利,一起加油! 至于为什么使用 Django,也不想说太多.个人喜欢,这里不做介绍.直接进入主题.show me the code!!! python 的环 ... 
- django 初试
		/************************************************************************************** * django 初试 ... 
- Ubuntu Nginx uwsgi django 初试
		/************************************************************************************** * Ubuntu Ngi ... 
- Django学习笔记二
		Django学习笔记二 模型类,字段,选项,查询,关联,聚合函数,管理器, 一 字段属性和选项 1.1 模型类属性命名限制 1)不能是python的保留关键字. 2)不允许使用连续的下划线,这是由dj ... 
- Django之Models(二)
		Django之Models(二) 创建一对多的关系 一个出版商可以有多本出版的书 一本书只有一个出版商 创建一对多的语法: 字段名= models.ForeignKey(关联表(类名),on_dele ... 
- Django开发笔记二
		Django开发笔记一 Django开发笔记二 Django开发笔记三 Django开发笔记四 Django开发笔记五 Django开发笔记六 1.xadmin添加主题.修改标题页脚和收起左侧菜单 # ... 
- {django模型层(二)多表操作}一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询、分组查询、F查询和Q查询
		Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 xxx 七 ... 
- 基于Ubuntu Server 16.04 LTS版本安装和部署Django之(二):Apache安装和配置
		基于Ubuntu Server 16.04 LTS版本安装和部署Django之(一):安装Python3-pip和Django 基于Ubuntu Server 16.04 LTS版本安装和部署Djan ... 
随机推荐
- leetcode腾讯精选练习之旋转链表(四)
			旋转链表 题目: 给定一个链表,旋转链表,将链表每个节点向右移动 k 个位置,其中 k 是非负数. 示例 1: 输入: 1->2->3->4->5->NULL, k = ... 
- R语言入门:向量初探
			R语言主要用于统计,因此引入了向量这个概念将更好地进行统计计算,在其他无法引入向量的语言当中则会使用循环来计算一些大规模的数据,在R语言当中则不需要,下面我们来看看R语言当中向量的具体用法吧! 首先, ... 
- thinkphp 5.0 后台数据修改
			html代码 <table class="easyui-datagrid" data-options="singleSelect:true,collapsible: ... 
- vue 学习2
			模板指令.属性总结 html 中的标签属性 1. :class 值是对象,key为class 的值,值为boolean类型 html标签任意属性都可以:属性,表示动态值(值是变化的,不是固定不变的) ... 
- cc.fade.fade
			用cc.fadeIn之前要先把setOpacity(0),笑哭,啊啊啊啊啊.因为这个东西卡了好久,啊啊啊 
- HDU6683
			题意 英文 做法 考虑公比为\(\frac{a}{b}\),满足\(a>b,(a,b)=1\) 枚举长度\(k\),设序列头为\(p\),尾为\(q\),有\(p\times \frac{a^{ ... 
- 为什么重写equals方法,还必须要重写hashcode方法
			一.equals方法和hashcode的关系 根据Object.hashCode的通用约定: 如果两个对象相同(equals方法返回true),那么hashcode也相等.(图1) 如果两个对象的ha ... 
- BZOJ4566&&lg3181 HAOI找相同字符(广义后缀自动机)
			BZOJ4566&&lg3181 HAOI找相同字符(广义后缀自动机) 题面 自己找去 HINT 给定两个文本串,问从两个串中各取一个非空子串,使这俩子串相同,问方案有多少种.我的思路 ... 
- Linux c++ string转其他类型
			#include <iostream> #include <sstream> #include <string> using namespace std; temp ... 
- MySQL 8  通用二进制发行版安装
			安装前的一些说明: 检查平台兼容性: https://www.mysql.com/support/supportedplatforms/database.html 如果是在RedHat7版本安装的话, ... 
