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

当你考虑开发现代化、高效且可扩展的网站和Web应用时,Django是一个强大的选择。Django是一个流行的开源Python Web框架,它提供了一个坚实的基础,帮助开发者快速构建功能丰富且高度定制的Web应用

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


共 10 章,31 子模块


模板

模板使用

1. 配置模板目录

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

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

django-004

2. 定义模板文件

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

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <!-- 显示模板变量 -->
    <h1>{{ name }}</h1>

</body>
</html>

3. 模板渲染

方式一: 通过render函数

from django.shortcuts import render

def index(request):
    context = {'name': 'django' }
    # 参数1:请求对象
    # 参数2:模块路径
    # 参数3:字典数据
    return render(request, 'index.html', context)

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

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. 模板变量

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

{{ 变量 }}

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

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)
<!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循环:

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

2)if条件:

{% if ... %}
    逻辑1
{% elif ... %}
    逻辑2
{% else %}
    逻辑3
{% endif %}

比较运算符如下:

==
!=
<
>
<=
>=

布尔运算符如下:

and
or
not

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

{% if a == 1 %}  # 正确
{% if a==1 %}  # 错误

3. 过滤器

语法如下:

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

列举几个如下:

  • safe,禁用html转义(显示html标签样式,而不是字符串)
  • length,长度,返回字符串包含字符的个数,或列表、元组、字典的元素个数。
  • default,默认值,如果变量不存在时则返回默认值。
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。
value|date:"Y年m月j日  H时i分s秒"

4. 注释

1)单行注释语法如下:

{#...#}

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

{% comment %}
...
{% endcomment %}

5. 模板继承

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

父模板

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

{% block 块名称 %}
    预留区域,可以编写默认内容,也可以没有默认内容
{% endblock %}

子模板

  1. 使用extends标签继承父模板,写在子模板文件的第一行。
{% 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

  • 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
create database db_django01 charset=utf8;
  1. 在与项目 setting.py 文件中配置使用mysql
DATABASES = {
     'default': {
         # 配置使用mysql
         'ENGINE': 'django.db.backends.mysql',     # 数据库产品
         'HOST': "localhost",           # 数据库ip
         'PORT': 3306,                  # 数据库端口
         'USER': "root",                # 用户名
         'PASSWORD': "mysql",           # 密码
         'NAME': "db_django01",         # 数据库名
     }
 }
  1. 在python虚拟环境下安装 MySQL 驱动
pip install pymysql
  1. 与项目同名的包 下的 __init__.py 文件中,初始化MySQL驱动
import pymysql
 pymysql.install_as_MySQLdb()

二、迁移命令生成表

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

1. 生成迁移文件

python manage.py makemigrations

2. 生成数据库表

python manage.py migrate

3. 查看数据库表

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类指定表名,例如
  
  
# 如果应用名为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_addauto_now是相互排斥的,不能同时用到一个属性中
TimeField时间,参数同DateField
DateTimeField日期时间,参数同DateField
FileField上传文件字段
ImageField继承于FileField,对上传的内容进行校验,确保是有效的图片
4. 字段选项
选项默认值描述是否要迁移修改表结构
nullFalseTrue表示表字段允许为空
uniqueFalseTrue表示表字段不能重复
db_column属性名称表字段名称
primary_keyFalseTrue表示字段设置为了主键,一般作为AutoField的选项使用
default-默认值
blankFalse在django管理后台新增或编辑一条表数据时,该字段是否允许为空;null是数据库范畴的概念,blank是表单验证范畴的
choices-在django管理后台新增或编辑一条表数据时,该字段显示为下拉框,默认为编辑框
  • choices: 性别属性使用了choices选项后,在录入一条数据时,会以下拉框显示
  • blank:blank属性默认值为false, 表示录入一条数据时,当前字段必须填写,不能为空,否则js端js校验不通过,例如:下图的comment员工备注信息字段。

image

5. 外键

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

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


二、代码参考

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

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交互环境

python manage.py shell

image

2. 使用 PyCharmpython Console 窗口

image

未完待续 下一期下一章

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/183319.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Docker】从零开始:8.Docker命令:Commit提交命令

【Docker】从零开始&#xff1a;8.Docker命令:Commit命令 基本概念镜像镜像分层什么是镜像分层为什么 Docker 镜像要采用这种分层结构 本章要点commit 命令命令格式docker commit 操作参数实例演示1.下载一个新的ubuntu镜像2.运行容器3.查看并安装vim4.退出容器5提交自己的镜像…

51单片机应用从零开始(八)·循环语句(for循环、while 语句、do‐while 语句)

51单片机应用从零开始&#xff08;七&#xff09;循环语句&#xff08;if语句&#xff0c;swtich语句&#xff09;-CSDN博客 目录 1. 用for 语句控制蜂鸣器鸣笛次数 2. 用while 语句控制 LED 3. 用 do‐while 语句控制 P0 口 8 位 LED 流水点亮 1. 用for 语句控制蜂鸣器鸣笛…

009 OpenCV 二值化 threshold

一、环境 本文使用环境为&#xff1a; Windows10Python 3.9.17opencv-python 4.8.0.74 二、二值化算法 2.1、概述 在机器视觉应用中&#xff0c;OpenCV的二值化函数threshold具有不可忽视的作用。主要的功能是将一幅灰度图进行二值化处理&#xff0c;以此大幅降低图像的数…

Linux:文件系统初步理解

文章目录 文件的初步理解C语言中对文件的接口系统调用的接口位图的理解open调用接口 文件和进程的关系进程和文件的低耦合 如何理解一切皆文件&#xff1f; 本篇总结的是关于Linux中文件的各种知识 文件的初步理解 在前面的文章中有两个观点&#xff0c;1. 文件 内容 属性&…

手撕A*算法(详解A*算法)

A*算法原理 全局路径规划算法&#xff0c;根据给定的起点和终点在全局地图上进行总体路径规划。 导航中使用A*算法计算出机器人到目标位置的最优路线&#xff0c;一般作为规划的参考路线 // 定义地图上的点 struct Point {int x,y; // 栅格行列Point(int x, int y):x(x),y(y){…

51单片机利用I/O口高阻状态实现触摸控制LED灯

51单片机利用I/O口高阻状态实现触摸控制LED灯 1.概述 这篇文章介绍使用I/O口的高阻状态实现一个触摸控制LED灯亮灭的实验。该实验通过手触摸P3.7引脚&#xff0c;改变电平信号控制灯的亮灭。 2.实验过程 2.1.实验材料 名称型号数量单片机STC12C20521LED彩灯无1晶振12MHZ1电…

PDF 批量处理软件BatchOutput PDF mac中文版介绍

BatchOutput PDF mac是一款适用于 Mac 的 PDF 批量处理软件。它可以帮助用户将多个 PDF 文件进行异步处理&#xff0c;提高工作效率。 BatchOutput PDF 可以自动化执行许多任务&#xff0c;包括 PDF 文件的打印、转换、分割、压缩、加密、重命名等&#xff0c;而且它还可以将自…

开启数据库审计(db,extended级别或os级别),并将审计文件存放到/home/oracle/audit下

文章目录 开启数据库审计&#xff08;db,extended级别或os级别&#xff09;&#xff0c;并将审计文件存放到/home/oracle/audit下一. 简介二. 配置2.1. 审计是否安装2.2. 审计表空间迁移2.3. 审计参数2.4. 审计级别2.5. 其他审计选项2.6. 审计相关视图 三. 使用3.1. 开启/关闭审…

案例023:基于微信小程序的童装商城的设计与实现

文末获取源码 开发语言&#xff1a;Java 框架&#xff1a;SSM JDK版本&#xff1a;JDK1.8 数据库&#xff1a;mysql 5.7 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.5.4 小程序框架&#xff1a;uniapp 小程序开发软件&#xff1a;HBuilder X 小程序…

wpf使用CefSharp.OffScreen模拟网页登录,并获取身份cookie,C#后台执行js

目录 框架信息&#xff1a;MainWindow.xamlMainWindow.xaml.cs爬取逻辑模拟登录拦截请求Cookie获取 CookieVisitorHandle 框架信息&#xff1a; CefSharp.OffScreen.NETCore 119.1.20 MainWindow.xaml <Window x:Class"Wpf_CHZC_Img_Identy_ApiDataGet.MainWindow&qu…

关于前端上传

类似于 上面的传参form-data形式&#xff0c;第一个参数为上传的文件&#xff0c;第二个参数为json格式

Centos部署GitLab-备份恢复

1. 下载rpm包 wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/gitlab-ce-10.8.4-ce.0.el7.x86_64.rpm2. 安装依赖 yum -y install policycoreutils openssh-server openssh-clients postfix policycoreutils-python3. rpm安装 rpm -ivh gitlab-ce-10.8.4-ce.…

OpenStack云计算平台

目录 一、OpenStack 1、简介 2、硬件需求 3、网络 二、环境搭建 1、安全 2、主机网络 3、网络时间协议(NTP) 4、OpenStack包 5、SQL数据库 6、消息队列 7、Memcached 一、OpenStack 1、简介 官网&#xff1a;https://docs.openstack.org/2023.2/ OpenStack系统由…

git查看某个commit属于哪个分支方法(如何查看commit属于哪个分支)

有时候&#xff0c;当我们由于业务需求很多时&#xff0c;基于同一个分支新建的项目分支也会很多。 在某个时间节点&#xff0c;我们需要合并部分功能点时&#xff0c;我们会忘了这个分支是否已经合入哪个功能点&#xff0c;我们就会查看所有的commit记录&#xff0c;当我们找到…

Jmeter快速入门

文章目录 1.安装Jmeter1.1.下载1.2.解压1.3.运行 2.快速入门2.1.设置中文语言2.2.基本用法 1.安装Jmeter Jmeter依赖于JDK&#xff0c;所以必须确保当前计算机上已经安装了JDK&#xff0c;并且配置了环境变量。 1.1.下载 可以Apache Jmeter官网下载&#xff0c;地址&#xf…

Word中如何实现 图片 | 表格 自动编号与文中引用编号对应

当我们在进行大篇幅word文档的编写时&#xff0c;为了节约修改文章中图片或表格所花费的大量时间&#xff0c;可以将图片自动编号&#xff0c;且让文中引用的顺序跟着图片顺序的变化而变化&#xff0c;具体操作如下&#xff1a; 1. 将鼠标定位在图片或者表格欲加编号的下方或上…

【SpringBoot3+Vue3】五【完】【实战篇】-前端(配合后端)

目录 一、环境准备 1、创建Vue工程 2、安装依赖 2.1 安装项目所需要的vue依赖 2.2 安装element-plus依赖 2.2.1 安装 2.2.2 项目导入element-plus 2.3 安装axios依赖 2.4 安装sass依赖 3、目录调整 3.1 删除部分默认目录下文件 3.1.1 src/components下自动生成的…

2.HTML入门

目录 一.HTML介绍 二.HTML常用标签 2.1 标题标签 2.2 段落标签 2.3 超链接标签 2.4 图片标签 2.5 换行与空格 2.6 布局标签 2.7 列表标签 2.8 表单标签 一.HTML介绍 定义&#xff1a;将内容显示在网页&#xff0c;用来描述网页的一种语言&#xff0c;负责网页的架构…

objdump反汇编文件解析

命令使用 objdump可以对可执行文件进行反汇编 其常用参数为: objdump -d <file(s)>: 将代码段反汇编&#xff1b;objdump -S <file(s)>: 将代码段反汇编的同时&#xff0c;将反汇编代码与源代码交替显示&#xff0c;编译时需要使用-g参数&#xff0c;即需要调试信…

常见树种(贵州省):014槭树、梧桐、鹅掌楸、檫木、梓木、油桐、泡桐、川楝、麻楝

摘要&#xff1a;本专栏树种介绍图片来源于PPBC中国植物图像库&#xff08;下附网址&#xff09;&#xff0c;本文整理仅做交流学习使用&#xff0c;同时便于查找&#xff0c;如有侵权请联系删除。 图片网址&#xff1a;PPBC中国植物图像库——最大的植物分类图片库 一、色木槭…