文章目录
静态文件
- 什么是静态文件
不能与服务器端做动态交互的文件都是静态文件,如:图片,css,js,音频,视频,html文件(部分) - 静态文件配置
在 settings.py 中配置以下两项内容:
- 配置静态文件的访问路径:
STATIC_URL = '/static/'
说明:指定访问静态文件时是需要通过 /static/xxx或 127.0.0.1:8000/static/xxx - 配置静态文件在服务器端的存储位置
STATICFILES_DIRS
# file: setting.py STATICFILES_DIRS = (os.path.join(BASE_DIR, "static"), )
- 访问静态文件
- 使用静态文件的访问路径进行访问
访问路径: STATIC_URL = ‘/static/’<img src="/static/images/lena.jpg"> <img src="http://127.0.0.1:8000/static/images/lena.jpg">
- 通过
{% static %}
标签访问静态文件
{% static %}
表示的就是静态文件访问路径
1.加载 static:{% load static %}
2.使用静态资源时:{% static '静态资源路径' %}
3.此seetings设置静态文件的方案,只适用于测试开发环境,正式上线后,将采取新方案解决:{% load static %}<img src="{% static 'images/lena.jpg' %}">
- nginx 挂载静态文件
- CDN内容网络服务[阿里云 网宿 蓝讯],将所有静态文件交由CDN公司即可,我们只需要在代码中所有src地址填写成CDN公司提供的地址域名(CDN - 用户请求静态资源时,解析用户所在位置信息,将请求调度到离用户最近的服务器上,减少无必要网络层跳转)
Django中的应用 - app
应用在Django项目中是一个独立的业务模块,可以包含自己的路由,视图,模板,模型
创建应用
- 创建步骤
1.用manage.py 中的子命令 startapp 创建应用文件夹
2.在settings.py 的 INSTALLED_APPS 列表中配置安装此应用python3 manage.py startapp 应用名称(必须是标识符命令规则) python3 manage.py startapp music
- Django应用的结构组成
1.migrations
文件夹:保存数据迁移的中间文件
2.__init__.py
:应用子包的初始化文件
3.admin.py
:应用的后台管理配置文件
4.apps.py
:应用的属性配置文件
5.models.py
:与数据库相关的模型映射类文件
6.tests.py
:应用的单元测试文件
7.views.py
:定义视图处理函数的文件 - 配置安装应用
在 settings.py 中配置应用, 让此应用能和整个项目融为一体# file : settings.py INSTALLED_APPS = [ ... ..., '自定义应用名称' ]
INSTALLED_APPS = [ # .... 'user', # 用户信息模块 'music', # 收藏模块 ]
应用的分布式路由
Django中,基础路由配置文件(urls.py)可以不处理用户具体路由,可以做请求的分发(分布式请求处理)。具体的请求可以由各自的应用来进行处理
include 函数
-
作用:将当前路由分发到各个应用的路由配置文件中的 urlpatterns 进行分布式处理
-
函数格式:include(‘app名字.url模块名’)
模块
app名字/url模块名.py
文件里必须有urlpatterns 列表
使用前需要使用from django.conf.urls import include
导入此函数 -
应用下templates 和 外层templates 都存在时,django的查找模板规则
- 优先查找外层templates目录下的模板
- 按INSTALLED_APPS配置下的 应用顺序 逐层查找
- 注意:一定要先创建应用,再注册应用,反之则报错。
Django中数据库操作
Django下配置使用 mysql 数据库
- 安装 pymysql包
- 用作 python 和 mysql 的接口:
$ sudo pip3 install pymysql
- 安装 mysql 客户端(非必须):
$ sudo pip3 install mysqlclient
- 创建和配置数据库
- 创建数据库
create database 数据库名 charset=utf8;
- 数据库的配置
- sqlite 数据库配置
# file: settings.py DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } }
- mysql 数据库配置
DATABASES = { 'default' : { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'mysitedb', # 数据库名称,需要自己定义 'USER': 'root', 'PASSWORD': '123456', # 管理员密码 'HOST': '127.0.0.1', 'PORT': 3306, } }
- 数据库的settings设置
- ENGINE:指定数据库的后端引擎
'django.db.backends.mysql' 'django.db.backends.sqlite3' 'django.db.backends.oracle' 'django.db.backends.postgresql' 'django.db.backends.mysql'
- NAME:指定要连接的数据库的名称
- USER:指定登录到数据库的用户名
- PASSWORD:数据库密码
- HOST:连接数据库时使用哪个主机
- PORT:连接数据库时使用的端口
- ENGINE:指定数据库的后端引擎
- sqlite 数据库配置
- 添加 mysql 支持
- 安装pymysql 模块:
$ sudo pip install pymysql
- 修改项目中__init__.py 加入如下内容来提供pymysql引擎的支持
import pymysql pymysql.install_as_MySQLdb()
数据库的迁移
迁移是Django同步模型所做更改到数据库模式的方式
- 生成或更新迁移文件
将每个应用下的models.py文件生成一个中间文件,并保存在migrations
文件夹中python3 manage.py makemigrations
- 执行迁移脚本程序
执行迁移程序实现迁移。将每个应用下的migrations目录中的中间文件同步回数据库python3 manage.py migrate
- 注:
- 每次修改完模型类再对服务程序运行之前都需要做以上两步迁移操作
- 生成迁移脚本文件
0001_initial.py
并进行迁移
数据库迁移的错误处理方法
当将如下代码去掉 null=True
class Book(models.Model):
title = models.CharField("书名", max_length=50, null=True)
执行 $ python3 manage.py makemigrations
出现迁移错误时的处理方法
- 错误信息
$ python3 manage.py makemigrations You are trying to change the nullable field 'title' on book to non-nullable without a default; we can't do that (the database needs something to populate existing rows). Please select a fix: 1) Provide a one-off default now (will be set on all existing rows with a null value for this column) 2) Ignore for now, and let me handle existing rows with NULL myself (e.g. because you added a RunPython or RunSQL operation to handle NULL values in a previous data migration) 3) Quit, and let me add a default in models.py Select an option:
- 翻译如下:
$ python3 manage.py makemigrations 您试图将图书上的可空字段“title”更改为非空字段(没有默认值);我们不能这样做(数据库需要填充现有行)。 请选择修复: 1)现在提供一次性默认值(将对所有现有行设置此列的空值) 2)暂时忽略,让我自己处理空值的现有行(例如,因为您在以前的数据迁移中添加了RunPython或RunSQL操作来处理空值) 3)退出,让我在models.py中添加一个默认值 选择一个选项:
- 原理:此数据库的 title 字段由原来的可以为 NULL 改为 非NULL 状态,意味着原来这个字段可以不填值,现在改为必须填一个值,那填什么值呢?此时必须添加一个缺省值。
- 处理方法:
手动给出一个缺省值,在生成 `000x_auto_xxxxxxxx_xxxx.py` 文件时自动将输入的值添加到default参数中 暂时忽略,以后用其它的命令处理缺省值问题(不推荐) 退出当前生成迁移文件的过程,自己去修改models.py, 新增加一个`default=XXX` 的缺省值(推荐使用)
- 数据库的迁移文件混乱的解决办法
删除所有 migrations 里所有的 000?_XXXX.py (__init__.py 除外) 删除数据库 mysql> drop database mysitedb; 重新创建数据库 mysql> create datebase mywebdb charset=utf8; 重新生成migrations里所有的中间文件 python3 manage.py makemigrations 重新更新数据库 python3 manage.py migrate
数据库的基本操作
- 数据库的基本操作包括增删改查,即(CRUD操作)
- CRUD是指在做计算处理时的增加(Create)、读取查询(Read)、更新(Update)和删除(Delete)
管理器对象
- 每个继承自 models.Model 的模型类,都会有一个 objects 对象被同样继承下来。这个对象叫管理器对象
- 数据库的增删改查可以通过模型的管理器实现
class MyModel(models.Model): ... MyModel.objects.create(...) # objects 是管理器对象
创建数据对象
- Django 使用一种直观的方式把数据库表中的数据表示成Python 对象
- 创建数据中每一条记录就是创建一个数据对象
- MyModel.objects.create(属性1=值1, 属性2=值1,…)
成功: 返回创建好的实体对象
失败: 抛出异常 - 创建 MyModel 实例对象,并调用 save() 进行保存
obj = MyModel(属性=值,属性=值) obj.属性=值 obj.save()
Django中的模型操作
- 模型是一个Python类,它是由django.db.models.Model派生出的子类。
- 一个模型类代表数据库中的一张数据表。
- 模型类中每一个类属性都代表数据库中的一个字段。
- 模型是数据交互的接口,是表示和操作数据库的方法和方式。
Django的ORM框架
ORM(Object Relational Mapping)即对象关系映射,是一种程序技术,允许使用类和对象对数据库进行操作,从而避免通过SQL语句操作数据库
-
ORM的作用
- 建立模型类和表之间的对应关系,允许我们通过面向对象的方式来操作数据库
- 根据设计的模型类生成数据库中的表格
- 通过简单的配置就可以进行数据库的切换
-
ORM 的好处
-
只需要面向对象编程, 不需要面向数据库编写代码
对数据库的操作都转化成对类属性和方法的操作
不用编写各种数据库的sql语句 -
实现了数据模型与数据库的解耦, 屏蔽了不同数据库操作上的差异
不在关注用的是mysql、oracle…等数据库的内部细节
通过简单的配置就可以轻松更换数据库, 而不需要修改代码
-
-
ORM 的缺点
- 相比较直接使用SQL语句操作数据库,有性能损失
- 根据对象的操作转换成SQL语句,根据查询的结果转化成对象, 在映射过程中有性能损失
-
模型示例:
- 此示例添加一个 bookstore_book 数据表来存放图书馆中书目信息
- 添加一个 bookstore 的 app
$ python3 manage.py startapp bookstore
- 添加模型类并注册app
# file : bookstore/models.py from django.db import models class Book(models.Model): title = models.CharField("书名", max_length=50, default='') price = models.DecimalField('定价', max_digits=7, decimal_places=2, default=0.0)
- 注册app
# file : setting.py INSTALLED_APPS = [ ... 'bookstore', ]
编写模型类Models
- 模型类需继承自
django.db.models.Model
- Models的语法规范
from django.db import models class 模型类名(models.Model): 字段名 = models.字段类型(字段选项)
- 模型类名是数据表名的一部分,建议类名首字母大写
- 字段名又是当前类的类属性名,此名称将作为数据表的字段名
- 字段类型用来映射到数据表中的字段的类型
- 字段选项为这些字段提供附加的参数信息
字段类型
- BooleanField()
数据库类型:tinyint(1) 编程语言中使用True或False来表示值 在数据库中使用1或0来表示具体的值
- CharField()
数据库类型:varchar(1字节存储当前实际存储长度) 注意:必须要指定max_length参数值
- DateField()
数据库类型:date 作用:表示日期 编程语言中:使用字符串来表示具体值 参数: - DateField.auto_now: 每次保存对象时,自动设置该字段为当前时间(取值:True/False)。 - DateField.auto_now_add: 当对象第一次被创建时自动设置当前时间(取值:True/False)。 - DateField.default: 设置当前时间(取值:字符串格式时间如: '2019-6-1')。 以上三个参数只能多选一
- DateTimeField()
数据库类型:datetime(6) 作用:表示日期和时间 auto_now_add=True
- DecimalField()
数据库类型:decimal(x,y) 编程语言中使用小数表示该列的值 在数据库中使用小数 参数: - DecimalField.max_digits: 位数总数,包括小数点后的位数。 该值必须大于等于decimal_places. - DecimalField.decimal_places: 小数点后的数字数量
money=models.DecimalField( max_digits=7, decimal_places=2, default=0.0 )
- FloatField()
数据库类型:double 编程语言中和数据库中都使用小数表示值
- EmailField()
数据库类型:varchar 编程语言和数据库中使用字符串
- IntegerField()
数据库类型:int 编程语言和数据库中使用整数
- URLField()
数据库类型:varchar(200) 编程语言和数据库中使用字符串
- ImageField()
数据库类型:varchar(100) 作用:在数据库中为了保存图片的路径(路径地址) 编程语言和数据库中使用字符串 参数: - upload_to:指定图片的上传路径 在后台上传时会自动的将文件保存在指定的目录下
image=models.ImageField( upload_to="static/images" )
- TextField()
数据库类型:longtext 作用:表示不定长的字符数据
参考文档 https://docs.djangoproject.com/en/1.11/ref/models/fields/#field-types
字段选项
- 字段选项, 指定创建的列的额外的信息
- 允许出现多个字段选项,多个选项之间使用逗号隔开
primary_key
:如果设置为True,表示该列为主键,如果指定一个字段为主键,则此数库表不会创建id字段blank
:设置为True时,字段可以为空。设置为False时,字段是必须填写的null
:如果设置为True,表示该列值允许为空。默认为False,如果此选项为False建议加入default选项来设置默认值default
:设置所在列的默认值,如果字段选项null=False建议添加此项db_index
:如果设置为True,表示为该列增加索引unique
:如果设置为True,表示该字段在数据库中的值必须是唯一(不能重复出现的)db_column
:指定列的名称,如果不指定的话则采用属性名作为列名verbose_name
:设置此字段在admin界面上的显示名称。
# 创建一个属性,表示用户名称,长度30个字符,必须是唯一的,不能为空,添加索引
name = models.CharField(max_length=30, unique=True, null=False, db_index=True)
参考文档 https://docs.djangoproject.com/en/1.11/ref/models/fields/#field-options
Django shell 的使用
- 在Django提供了一个交互式的操作项目叫
Django Shell
它能够在交互模式中用项目工程的代码执行相应的操作 - 利用 Django Shell 可以代替编写View的代码来进行直接操作
- 在Django Shell 下只能进行简单的操作,不能运行远程调式
- 启动方式:
$ python3 manage.py shell