前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Django使用】10大章31模块md文档,第5篇:Django模板和数据库使用

【Django使用】10大章31模块md文档,第5篇:Django模板和数据库使用

原创
作者头像
程序员一诺
发布2023-11-23 20:39:16
1570
发布2023-11-23 20:39:16
举报
文章被收录于专栏:知识集合知识集合
当你考虑开发现代化、高效且可扩展的网站和Web应用时,Django是一个强大的选择。Django是一个流行的开源Python Web框架,它提供了一个坚实的基础,帮助开发者快速构建功能丰富且高度定制的Web应用

全套Django笔记直接地址: 请移步这里


共 10 章,31 子模块


模板

模板使用

1. 配置模板目录

如果命令行创建的项目,需要手动配置模板文件目录,如果是Pycharm创建的项目,则无需配置

  1. 在项目根目录下创建模板目录,比如叫 templates,后续开发模板文件会放在此目录下
  2. 在项目的配置文件settings.py文件中,进行模板目录的配置,如下:
django-004
django-004

2. 定义模板文件

templates目录中新建一个模板文件,如index.html

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <!-- 显示模板变量 -->
    <h1>{{ name }}</h1>
?
</body>
</html>

3. 模板渲染

方式一: 通过render函数

代码语言:javascript
复制
from django.shortcuts import render
?
def index(request):
    context = {'name': 'django' }
    # 参数1:请求对象
    # 参数2:模块路径
    # 参数3:字典数据
    return render(request, 'index.html', context)

方式二: 通过Template对象的render方法

代码语言:javascript
复制
from django.template import loader
?
def index(request):
    # 模板对象
    template = loader.get_template('index.html')  # type: Template
    # 渲染得到字符串
    html_str = template.render(context)
    # 响应请求
    return HttpResponse(html_str)

模板语法

  1. 模板变量
  2. 模板语句
  3. 过滤器
  4. 注释
  5. 模板继承

1. 模板变量

变量名必须由字母、数字、下划线(不能以下划线开头)和点组成,语法如下:

代码语言:javascript
复制
{{ 变量 }}

模板变量可以使python的内建类型,也可以是对象。

代码语言:javascript
复制
def index(request):
    context = {
        'name': 'django',
        'my_list': ['python', 'java', 'php', 'c/c++'],
        'my_dict': {
            'name': 'python',
            'age': 20,
            'gender': '男',
        }
    }
    return render(request, 'index.html', context)
代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>{{ name }}</h1>
    <h1>{{ my_list }}</h1>  
    <h1>{{ my_list.0 }}</h1>   <!-- 注意列表的取值方法 -->
    <h1>{{ my_dict }}</h1>
    <h1>{{ my_dict.name }}</h1>  <!-- 注意字典的取值方法 -->
</body>
</html>

2. 模板语句

1)for循环:

代码语言:javascript
复制
{% for item in 列表 %}
    {{forloop.counter}}  <1-- 表示当前是第几次循环,从1开始 -->
    {{forloop.counter0}}  <!-- 表示当前是第几次循环,从0开始 -->
{% empty %} 
    列表为空或不存在时执行此逻辑
{% endfor %}

2)if条件:

代码语言:javascript
复制
{% if ... %}
    逻辑1
{% elif ... %}
    逻辑2
{% else %}
    逻辑3
{% endif %}

比较运算符如下:

代码语言:javascript
复制
==
!=
<
>
<=
>=

布尔运算符如下:

代码语言:javascript
复制
and
or
not

注意:运算符左右两侧必须有空格。

代码语言:javascript
复制
{% if a == 1 %}  # 正确
{% if a==1 %}  # 错误

3. 过滤器

语法如下:

  • 使用管道符号|来应用过滤器,用于进行计算、转换操作,可以使用在变量、标签中。
  • 如果过滤器需要参数,则使用冒号:传递参数。
代码语言:javascript
复制
变量|过滤器:参数

列举几个如下:

  • safe,禁用html转义(显示html标签样式,而不是字符串)
  • length,长度,返回字符串包含字符的个数,或列表、元组、字典的元素个数。
  • default,默认值,如果变量不存在时则返回默认值。
代码语言:javascript
复制
data|default:'默认值'
  • date,日期,用于对日期类型的值进行字符串格式化,常用的格式化字符如下:
    • Y表示年,格式为4位,y表示两位的年。
    • m表示月,格式为01,02,12等。
    • d表示日, 格式为01,02等。
    • j表示日,格式为1,2等。
    • H表示时,24进制,h表示12进制的时。
    • i表示分,为0-59。
    • s表示秒,为0-59。
代码语言:javascript
复制
value|date:"Y年m月j日  H时i分s秒"

4. 注释

1)单行注释语法如下:

代码语言:javascript
复制
{#...#}

2)多行注释使用comment标签,语法如下:

代码语言:javascript
复制
{% comment %}
...
{% endcomment %}

5. 模板继承

  • 模板继承和类的继承含义是一样的
  • 可以使用模板继承来复用父模板,提高代码的复用性,减轻开发人员的工作量。
  • 可以通过定义 block ,实现子模板对父模块内容的重写

父模板

如果发现在多个模板中某些内容相同,那就可以使用block标签把这段内容定义到父模板中。

代码语言:javascript
复制
{% block 块名称 %}
    预留区域,可以编写默认内容,也可以没有默认内容
{% endblock %}

子模板

  1. 使用extends标签继承父模板,写在子模板文件的第一行。
代码语言:javascript
复制
{% extends "父模板路径" %}
  1. 对有需要的block进行重写:
    • 不用重写父模版中的所有block,如果子模版没有重写,则使用父模版定义的默认值。
    • 可以使用 block.super 来包含父模板的块中定义的内容,如下

    {% block 名称 %} 子模板的内容 {{ block.super }} 显示父模板中block的内容 {% endblock %}

数据库

学习目标

  • 能够进行Django数据库配置
  • 掌握Django中模型类的定义
  • 掌握Django中的迁移命令的使用
  • 能够使用Django的ORM进行数据库的增删改查
  • 能够说明查询集QuerySet的特点
  • 能够说明模型类管理器Manager的作用

数据库

ORM框架

  • ORM Object relational mapping 对象关系映射
  • 把类和数据库表对应,把对象和表记录对应,通过类和对象操作数据库表中的数据,而不需要编写SQL语句
ORM
ORM
  • Django框架实现了ORM 功能:
    • 不需要直接面向数据库编程,通过模型类和对象完成数据表的增删改查操作
    • 自动生成数据库表
    • 通过配置切换使用不同的数据库
  • ORM 开发步骤
    1. 配置数据库
    2. 定义模型类 (models.py)
    3. 执行迁移命令,生成数据库表
      1. 生成迁移文件: python manage.py makemigrations
      2. 生成数据库表: python manage.py migrate
      3. 默认数据库为 sqlite3,数据库名为:db.sqlite3
    4. 通过模型类和对象操作数据库

数据库配置和迁移

  • Django项目默认 sqlite3 数据库, 生成的数据库名为 db.sqlite3
  • sqlite3 仅供测试使用,可以通过配置修改为使用 mysql

一、配置使用MySQL数据库

  1. 手动创建 MySQL 数据库,比如叫: db_django01
代码语言:javascript
复制
create database db_django01 charset=utf8;
  1. 在与项目 setting.py 文件中配置使用mysql
代码语言:javascript
复制
DATABASES = {
     'default': {
         # 配置使用mysql
         'ENGINE': 'django.db.backends.mysql',     # 数据库产品
         'HOST': "localhost",           # 数据库ip
         'PORT': 3306,                  # 数据库端口
         'USER': "root",                # 用户名
         'PASSWORD': "mysql",           # 密码
         'NAME': "db_django01",         # 数据库名
     }
 }
  1. 在python虚拟环境下安装 MySQL 驱动
代码语言:javascript
复制
pip install pymysql
  1. 与项目同名的包 下的 __init__.py 文件中,初始化MySQL驱动
代码语言:javascript
复制
import pymysql
 pymysql.install_as_MySQLdb()

二、迁移命令生成表

打开终端,进入到项目根目录下,执行以下2个命令,生成数据库表

1. 生成迁移文件

代码语言:javascript
复制
python manage.py makemigrations

2. 生成数据库表

代码语言:javascript
复制
python manage.py migrate

3. 查看数据库表

image
image

?

一、需求

定义模型类,保存部门-员工数据

  • 部门类(Department)
    • 部门名称: name
    • 部门成立时间: create_date
    • 逻辑删除标识:is_delete
  • 员工类(Employee)
    • 性名: name
    • 年龄: age
    • 性别: sex
    • 工资: salary
    • 入职时间: hire_date
    • 备注信息: comment

二、模型类定义

  • 模型类被定义在 应用/models.py 文件中
  • 模型类必须继承自 Djangomodels.Model
1. 属性定义
  • 模型类属性与表字段一一对应
  • 定义属性时,需要指定字段类型,通过字段类型的参数指定选项,格式如下:
    • 属性名 = models.字段类型(字段选项)
  • 属性名不能是python的保留关键字
  • 属性名不能使用连续的下划线(这是由django的查询方式决定的)
2. 关于主键
  • 主键:primary key,简写 pk
  • 不需要主动定义,django会自动生成自增长的主键,属性名叫 id,
  • 如果开发者自己定义了主键,则django不会再生成默认的主键
3. 表名
  • 默认为:应用名小写_模型类名小写
  • 可通过通过Meta类指定表名,例如
代码语言:javascript
复制
# 如果应用名为users,则默认表名为:users_department
  
  
  class Department(models.Model):
      ...
      class Meta:
          # 指定生成的数据库表的名字
          db_table = 'department'
4. 字段类型

官方文档:字段类型和选项

类型

说明

AutoField

自动增长的IntegerField,通常不用指定,不指定时Django会自动创建名为id的自动增长属性

BooleanField

布尔字段,值为True或False

NullBooleanField

支持Null、True、False三种值

CharField

字符串,必须指定:max_length,表示最大字符个数

TextField

大文本字段,一般超过4000个字符时使用

IntegerField

整数

DecimalField

十进制浮点数,用python中的Decimal实例来表示必须指定: max_digits总位数,decimal_places小数位数。

FloatField

浮点数

DateField

日期1) 参数auto_now表示每次修改保存对象时,自动设置该字段为当前时间,用于保存"最后一次修改"时间,默认为False;2) 参数auto_now_add表示当对象第一次被创建时自动设置保存当前时间,用于保存"创建时间"时间,默认为值为False;3) 参数auto_now_add和auto_now是相互排斥的,不能同时用到一个属性中

TimeField

时间,参数同DateField

DateTimeField

日期时间,参数同DateField

FileField

上传文件字段

ImageField

继承于FileField,对上传的内容进行校验,确保是有效的图片

4. 字段选项

选项

默认值

描述

是否要迁移修改表结构

null

False

True表示表字段允许为空

unique

False

True表示表字段不能重复

db_column

属性名称

表字段名称

primary_key

False

True表示字段设置为了主键,一般作为AutoField的选项使用

default

-

默认值

blank

False

在django管理后台新增或编辑一条表数据时,该字段是否允许为空;null是数据库范畴的概念,blank是表单验证范畴的

choices

-

在django管理后台新增或编辑一条表数据时,该字段显示为下拉框,默认为编辑框

  • choices: 性别属性使用了choices选项后,在录入一条数据时,会以下拉框显示
  • blank:blank属性默认值为false, 表示录入一条数据时,当前字段必须填写,不能为空,否则js端js校验不通过,例如:下图的comment员工备注信息字段。
image
image
5. 外键

关系型数据库的关系包括三种类型

  • ForeignKey: 一对多,将 关联属性 定义在多的一端中
  • ManyToManyField: 多对多,将 关联属性 定义任意一方中
  • OneToOneField: 一对一,将 关联属性 定义在任意一方中

二、代码参考

部门和员工模型类 代码参考

代码语言:javascript
复制
class Department(models.Model):
    """部门类"""
?
    # 部门名称:字符串类型(必须要指定最大长度)
    name = models.CharField(max_length=20)
    # 部门成立时间: 日期类型
    create_date = models.DateField(auto_now_add=True)
    # 逻辑删除标识:标识部门是否删除
    is_delete = models.BooleanField(default=False)
?
    def __str__(self):
        return self.name
?
    class Meta: 
        # 指定表名
        db_table = 'department'
?
class Employee(models.Model):
    """员工类"""
?
    choices_gender = (
        (0, '男'),
        (1, '女'),
    )
?
    name = models.CharField(max_length=20)
    age = models.IntegerField()
    gender = models.IntegerField(default=0, choices=choices_gender)
    # 工资:浮点类型(必须要指定两个选项)  999999.99
    salary = models.DecimalField(max_digits=8, decimal_places=2)
    # 备注信息: 可以为空
    comment = models.CharField(max_length=300, null=True, blank=True)
    # 员工入职时间
    hire_date = models.DateField(auto_now_add=True)
    # 一对多的外键:员工所属部门 department_id
    department = models.ForeignKey('Department')
?
    def __str__(self):
        return self.name
?
    class Meta: 
        # 指定表名
        db_table = 'employee'

交互环境

Django交互环境

  • 在Django交互环境中,可以直接执行django项目代码,类似 ipython 交互环境
  • 有以下两种方式使用Django交互环境

1. 通过 shell 命令进入Django交互环境

代码语言:javascript
复制
python manage.py shell
image
image

2. 使用 PyCharmpython Console 窗口

image
image

未完待续 下一期下一章

全套笔记直接地址: 请移步这里

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
作者已关闭评论
0 条评论
热度
最新
推荐阅读
目录
  • 全套Django笔记直接地址: 请移步这里
    • 共 10 章,31 子模块
    • 模板
    • 模板使用
      • 1. 配置模板目录
        • 2. 定义模板文件
          • 3. 模板渲染
          • 模板语法
            • 1. 模板变量
              • 2. 模板语句
                • 3. 过滤器
                  • 4. 注释
                    • 5. 模板继承
                      • 学习目标
                  • 数据库
                  • 数据库
                    • ORM框架
                    • 数据库配置和迁移
                      • 一、配置使用MySQL数据库
                        • 二、迁移命令生成表
                          • 1. 生成迁移文件
                          • 2. 生成数据库表
                          • 3. 查看数据库表
                      • 一、需求
                        • 二、模型类定义
                          • 二、代码参考
                          • 交互环境
                            • Django交互环境
                              • 1. 通过 shell 命令进入Django交互环境
                              • 2. 使用 PyCharm 的 python Console 窗口
                            • 未完待续 下一期下一章
                            • 全套笔记直接地址: 请移步这里
                            相关产品与服务
                            云数据库 MySQL
                            腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
                            领券
                            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
                            http://www.vxiaotou.com