【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 renderdef index(request):context = {'name': 'django' }# 参数1:请求对象# 参数2:模块路径# 参数3:字典数据return render(request, 'index.html', context)

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

from django.template import loaderdef 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 pymysqlpymysql.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_departmentclass 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.nameclass 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.99salary = 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_iddepartment = models.ForeignKey('Department')def __str__(self):return self.nameclass Meta: # 指定表名db_table = 'employee'

交互环境

Django交互环境

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

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

python manage.py shell

image

2. 使用 PyCharmpython Console 窗口

image

未完待续 下一期下一章

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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

外汇天眼:多名投资者账户被恶意清空,远离volofinance!

最近&#xff0c;外汇平台volofinance因有多名投资者投诉&#xff0c;“荣幸”成为外汇天眼黑平台榜单中的一员&#xff0c;那么volofinance到底做了什么导致投资者前来投诉曝光呢&#xff1f; 起底volofinace 在网络搜索中&#xff0c;关于volofinance的信息少之又少&#xf…

成为AI产品经理——模型评估指标

目录 一、模型评估分类 1.在线评估 2.离线评估 二、离线模型评估 1.特征评估 ① 特征自身稳定性 ② 特征来源稳定性 ③ 特征成本 2.模型评估 ① 统计性评估 覆盖度 最大值、最小值 分布形态 ② 模型性能指标 分类问题 回归问题 ③ 模型的稳定性 模型评估指标分…

配置mvn打包参数,不同环境使用不同的配置文件

方法一&#xff1a; 首先在/resource目录下创建各自环境的配置 要在不同的环境中使用不同的配置文件进行Maven打包&#xff0c;可以使用Maven的profiles特性和资源过滤功能。下面是配置Maven打包参数的步骤&#xff1a; 在项目的pom.xml文件中&#xff0c;添加profiles配置…

第一个Mybatis项目

&#xff08;一&#xff09;为什么要用Mybatis? &#xff08;1&#xff09;Mybatis对比JDBC而言&#xff0c;sql&#xff08;单独写在xml的配置文件中&#xff09;和java编码分开&#xff0c;功能边界清晰&#xff0c;一个专注业务&#xff0c;一个专注数据。 &#xff08;2&…

【C++】:多态

朋友们、伙计们&#xff0c;我们又见面了&#xff0c;本期来给大家解读一下有关多态的知识点&#xff0c;如果看完之后对你有一定的启发&#xff0c;那么请留下你的三连&#xff0c;祝大家心想事成&#xff01; C 语 言 专 栏&#xff1a;C语言&#xff1a;从入门到精通 数据结…

Linux(CentOS7)上安装mysql

在CentOS中默认安装有MariaDB&#xff08;MySQL的一个分支&#xff09;&#xff0c;可先移除/卸载MariaDB。 yum remove mariadb // 查看是否存在mariadb rpm -qa|grep -i mariadb // 卸载 mariadb rpm -e --nodeps rpm -qa|grep mariadb yum安装 下载rpm // 5.6版本 wge…

XML映射文件

<?xml version"1.0" encoding"UTF-8" ?> <!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace"org.mybatis.example.BlogMapper&q…

conan 入门(三十二):package_info中配置禁用CMakeDeps生成使用项目自己生成的config.cmake

conanfile.py中定义的package_info()方法用于向package的调用者(conumer)提供包库名&#xff0c;编译/连接选项&#xff0c;文件夹等等信息&#xff0c;有了这些信息构建工具的generator就可以根据它们生成对应的文件&#xff0c;用于调用者引用package. 比如基于cmake的CMakeD…

安全地公网访问树莓派等设备的服务 内网穿透--frp 23年11月方法

如果想要树莓派可以被公网访问&#xff0c;可以选择直接网上搜内网穿透提供商&#xff0c;一个月大概10块钱&#xff0c;也有免费的&#xff0c;但是免费的速度就不要希望很好了。 也可以选择接下来介绍的frp&#xff0c;这种方式不需要付费&#xff0c;但是需要你有一台有着公…

vue3自定义拖拽指令

<template><div v-move class"box"></div> </template><script setup lang"ts"> import { Directive } from vue const vMove:Directive (el:HTMLElement) >{const mousedown (e:MouseEvent) >{// 鼠标按下const s…

【Golang】解决使用interface{}解析json数字会变成科学计数法的问题

在使用解析json结构体的时候&#xff0c;使用interface{}接数字会发现变成了科学计数法格式的数字&#xff0c;不符合实际场景的使用要求。 举例代码如下&#xff1a; type JsonUnmStruct struct {Id interface{} json:"id"Name string json:"name"…

Linux 的性能调优的思路

Linux操作系统是一个开源产品&#xff0c;也是一个开源软件的实践和应用平台&#xff0c;在这个平台下有无数的开源软件支撑&#xff0c;我们常见的apache、tomcat、mysql等。 开源软件的最大理念是自由、开放&#xff0c;那么Linux作为一个开源平台&#xff0c;最终要实现的是…

uniApp微信支付实现

后端&#xff1a;小程序下单 - 小程序支付 | 微信支付商户文档中心 服务端需要请求&#xff1a;https://api.mch.weixin.qq.com该地址获取微信支付Api接口需要的参数。 服务端请求接口需要的Body参数&#xff1a; 客户端&#xff08;前端&#xff09;需要调用&#xff1a;wx.…

12V降3.3V100mA稳压芯片WT7133

12V降3.3V100mA稳压芯片WT7133 WT71XX系列是一款采用CMOS工艺实现的三端高输入电压、低压差、小输出电流电压稳压器。 它的输出电流可达到100mA&#xff0c;输入电压可达到18V。其固定输出电压的范围是2.5V&#xff5e;8.0V&#xff0c;用户 也可通过外围应用电路来实现可变电压…

加载minio中存储的静态文件html,不显示样式与js

问题描述:点击链接获取的就是纯静态文件,但是通过浏览器可以看到明明加载了css文件与js文件 原因:仔细看你会发现加载css文件显示的contentType:text/html文件,原来是minio上传文件时将所有文件的contentType设置成了text/html 要在上传时指定文件,根据文章的类型指定的Conten…

win10开机黑屏只有鼠标?这份指南帮你轻松解决!

win10是一个出色的操作系统&#xff0c;但有时用户可能会遇到开机后只有鼠标显示在屏幕上的问题&#xff0c;这种情况可能会让人感到困惑和沮丧。在本文中&#xff0c;我们将介绍三种解决win10开机黑屏只有鼠标的方法&#xff0c;以帮助您快速恢复正常的桌面环境。 方法1&#…

Ubuntu18.4中安装wkhtmltopdf + Odoo16配置【二】

deepin Linux 安装wkhtmltopdf 1、先从官网的链接里下载linux对应的包 wkhtmltopdf/wkhtmltopdf 下载需要的版本&#xff0c;推荐版本&#xff0c;新测有效&#xff1a; wkhtmltox-0.12.4_linux-generic-amd64.tar.xz 2、解压下载的文件 解压后会有一个wkhtmltox文件夹 3…

CTA-GAN:基于生成对抗性网络的主动脉和颈动脉非集中CT血管造影 CT到增强CT的合成技术

Generative Adversarial Network–based Noncontrast CT Angiography for Aorta and Carotid Arteries 基于生成对抗性网络的主动脉和颈动脉非集中CT血管造影背景贡献实验方法损失函数Thinking 基于生成对抗性网络的主动脉和颈动脉非集中CT血管造影 https://github.com/ying-f…

可自行DIY单TYPE-C接口设备实现DRP+OTG功能芯片

随着USB-C接口的普及&#xff0c;欧盟的法律法规强制越来越多的设备开始采用这种接口。由于 USB-C接口的高效性和便携性&#xff0c;使各种设备之间的连接和数据传输变得非常方便快捷&#xff0c;它们不仅提供了强大的功能&#xff0c;还为我们的日常生活和工作带来了极大的便利…

ssm+vue的企业文档管理系统(有报告)。Javaee项目,ssm vue前后端分离项目。

演示视频&#xff1a; ssmvue的企业文档管理系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;ssm vue前后端分离项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&…