栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

Django笔记 使用QuerySet删除和查询单表

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Django笔记 使用QuerySet删除和查询单表

任务:如何去掉关于路由斜杠的警告
  • 修改主路由和子路由(斜杠加在主路由路径的尾巴上)

  • 运行项目

(一)删除数据

删除数据有3种方式:删除数据表的全部数据、删除一行数据和删除多行数据.

1、删除全部数据:all()与delete()
  • 在终端Shell模式下执行命令:Types.objects.all().delete(),删除全部记录

  • 查看commodity_types表

2、删除一行数据:get()与delete()
  • 导入数据有两种方式:一种是运行SQL脚本,一种是使用loaddata命令

  • 重新导入数据到表:python manage.py loaddata commodity_types_data.json

  • 查看commodity_types表

  • 在终端Shell模式下执行命令:Types.objects.get(id=1).delete(),删除id为1的记录

  • 查看commodity_types表

3、删除多行数据:filter()与delete()
任务:删除全部“儿童用品” (目前只有三条记录满足条件)
  • 在终端Shell模式下执行命令:Types.objects.filter(firsts=‘儿童用品’).delete()

  • 删除了3条记录,查看commodity_types表

4、删除有外键的数据:delete()

删除数据的过程中,如果删除的数据设有外键字段,就会同时删除外键关联的数据。

(1)准备模型和表
在index模块的models.py中定义以下2个模型类


  • 在终端执行数据迁移命令:python manage.py makemigrations

  • 在终端执行数据迁移命令,生成相应的数据表

  • 查看生成的两种表

(2)为index_personinfo准备测试数据

  • 查看index_personinfo表

(3)为index_vocation准备测试数据

  • 查看index_vocation表
(4)级联删除id=1的李红利
  • 执行命令:PersonInfo.objects.get(id=1).delete()
  • 删除成功,总共删除了2条数据,1条是index_personinfo表的记录,1条是index_vocation表的记录。
  • 查看index_personinfo表,“李红利”记录已被删除

  • 查看index_vocation表,级联的记录(外键name_id=1)已被删除

  • 往index_personinfo插入数据

  • 查看index_personinfo表记录

  • 往index_vocation插入数据

  • 查看index_vocation表记录

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/589526.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号