11.10 知识总结(数据的增删改查、如何创建表关系、Django框架的请求生命周期流程图)

一、 数据的增删改查

1.1 用户列表的展示

把数据表中得用户数据都给查询出来展示在页面上

添加数据

id username password gender age action

修改 删除

1.2 修改数据的逻辑分析

  1. 先确定修改哪条记录------>怎么样确定修改哪条记录?

  2. 通过什么字段可以确定唯一一条记录? 主键id,要携带主键id到后端.

  3. 在后端接收主键id值,然后根据这个id值再去表中查询数据,查询一条

  4. 然后把查询的数据在渲染到页面中,然后在修改

  5. 把修改之后的表单提交到后端,在做修改

1.3 删除功能的分析

  1. 给删除按钮加一个链接,携带当前记录的id值

  2. 后端要接收这个主键id值

  3. 后端直接执行删除操作

二、如何创建表关系(一对一,一对多,多对多)

"""

一对一

一对多

多对多

"""

我们以图书表、出版社表、作者表、作者详情表为例创建

判断表关系:换位思考法

分析表关系:

图书表和出版社表是一对多的关系 >>> 外键如何创建:外键字段建在多的一方

图书表和作者表是多对多的关系 >>> 外键如何创建:外键字段建在第三张表中

"""

创建多对多的方式有3种方式,先将一种

"""

作者表和作者详情是一对一的关系 >>> 外键如何创建:外键字段建在查询频率较高的一方

创建表关系字段先创建表的基础字段,先创建没有的外键的,最后在写外键字段

class Book(models.Model):

title = models.CharField(max_length=64)

"""

max_digits=None, 总共多少位

decimal_places=None 小数占几位

"""

price decimal(8,2)

price = models.DecimalField(max_digits=8, decimal_places=2)

publish_id = models.ForeignKey(to='Publish', to_field='id') # 创建外键的

"""如果你的字段是主键字段,那么,你就不用在字段的后面拼接_id了,它会自定的拼接_id"""

publish = models.ForeignKey(to='Publish') # 创建外键的 默认就是跟表的主键字段建立关系

"""

authors:它是一个虚拟字段,意思是,在book表中不会实际创建出来这个字段,它能够创建出来第三张表(自动)

"""

authors = models.ManyToManyField(to='Author', )

class Publish(models.Model):

title = models.CharField(max_length=64)

addr = models.CharField(max_length=64)

class Author(models.Model):

name = models.CharField(max_length=64)

author_detail = models.OneToOneField(to='AuthorDetail')

注意:

1.django1版本

on_delete
当删除关联表中的数据时,当前表与其关联的行的行为。

models.CASCADE
删除关联数据,与之关联也删除

models.DO_NOTHING
删除关联数据,引发错误IntegrityError

models.PROTECT
删除关联数据,引发错误ProtectedError

models.SET_NULL
删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空)

models.SET_DEFAULT
删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值)

models.SET

删除关联数据,

a. 与之关联的值设置为指定值,设置:models.SET(值)

b. 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)

  1. django2

class Book(models.Model):

title = models.CharField(max_length=64)

"""

max_digits=None, 总共多少位

decimal_places=None 小数占几位

"""

price decimal(8,2)

price = models.DecimalField(max_digits=8, decimal_places=2)

publish_id = models.ForeignKey(to='Publish', to_field='id') # 创建外键的

"""如果你的字段是主键字段,那么,你就不用在字段的后面拼接_id了,它会自定的拼接_id"""

publish = models.ForeignKey(to='Publish', on_delete=models.CASCADE) # 创建外键的 默认就是跟表的主键字段建立关系

"""

authors:它是一个虚拟字段,意思是,在book表中不会实际创建出来这个字段,它能够创建出来第三张表(自动)

"""

authors = models.ManyToManyField(to='Author', )

class Publish(models.Model):

title = models.CharField(max_length=64)

addr = models.CharField(max_length=64)

class Author(models.Model):

name = models.CharField(max_length=64)

author_detail = models.OneToOneField(to='AuthorDetail',on_delete=models.CASCADE)

class AuthorDetail(models.Model):

phone = models.CharField(max_length=64)

qq = models.CharField(max_length=64)

三、 Django的请求生命周期流程图

相关推荐
码界筑梦坊11 小时前
325-基于Python的校园卡消费行为数据可视化分析系统
开发语言·python·信息可视化·django·毕业设计
码界筑梦坊12 小时前
327-基于Django的兰州空气质量大数据可视化分析系统
python·信息可视化·数据分析·django·毕业设计·数据可视化
WangYaolove13141 天前
基于python的在线水果销售系统(源码+文档)
python·mysql·django·毕业设计·源码
意疏1 天前
程序员兼职如何选择靠谱的软件外包平台 与 我的避坑经验
django
vx_biyesheji00011 天前
豆瓣电影推荐系统 | Python Django 协同过滤 Echarts可视化 深度学习 大数据 毕业设计源码
大数据·爬虫·python·深度学习·django·毕业设计·echarts
心疼你的一切1 天前
解锁CANN仓库核心能力:从零搭建AIGC轻量文本生成实战(附代码+流程图)
数据仓库·深度学习·aigc·流程图·cann
玄同7651 天前
Python 后端三剑客:FastAPI/Flask/Django 对比与 LLM 开发选型指南
人工智能·python·机器学习·自然语言处理·django·flask·fastapi
B站_计算机毕业设计之家1 天前
豆瓣电影推荐系统 | Python Django Echarts构建个性化影视推荐平台 大数据 毕业设计源码 (建议收藏)✅
大数据·python·机器学习·django·毕业设计·echarts·推荐算法
心疼你的一切1 天前
基于CANN仓库算力手把手实现Stable Diffusion图像生成(附完整代码+流程图)
数据仓库·深度学习·stable diffusion·aigc·流程图·cann
熬夜敲代码的小N1 天前
AIGC高效落地利器:ops-nn仓库深度解析(含代码+流程图)
aigc·流程图