- 零、本讲学习目标
- 一、课程导入
- 二、新课讲授
- (一)删除数据
- 1、删除全部数据:all()与delete()
- 2、删除一行数据:get()与delete()
- 3、删除多行数据:filter()与delete()
- 4、删除有外键的数据:delete()
- (1)准备模型和表
- (2)为index_personinfo准备测试数据
- (3)为index_vocation准备测试数据
- (4)级联删除id=1的李红利
- 三、课堂小结
- 四、课后作业
- 五、拓展内容
- 掌握常用的删除记录的方式
- 掌握常用的查询数据的方式
- 掌握分组、排序、并、差、交操作
- 掌握多表查询
- 掌握原生SQL的3种查询方式
- Shell下新增数据的7种方式
- Shell下更新数据的6种方式
删除数据有3种方式:删除数据表的全部数据、删除一行数据和删除多行数据.
1、删除全部数据:all()与delete()- 查看commodity_types表(14条记录)
- 在终端Shell模式下执行命令:Types.objects.all().delete(),删除全部记录
- 查看commodity_types表
- 导入数据到表:python manage.py loaddata commodity_types_data.json
- 查看commodity_types表
- 在终端Shell模式下执行命令:Types.objects.get(id=2).delete(),删除id为2的记录
- 查看commodity_types表
- 在终端Shell模式下执行命令:Types.objects.filter(firsts='儿童用品').delete(),删除全部“儿童用品”
- 删除了4条记录,查看commodity_types表
删除数据的过程中,如果删除的数据设有外键字段,就会同时删除外键关联的数据。
(1)准备模型和表-
在index模块的models.py中定义以下2个模型类
第22行定义了name为外键,关联的是PeronInfo对象,而且是级联删除。从模型 Vocation 得知,外键字段的参数 on_delete 用于设置数据删除模式,比如模型 Vocation的外键字段name设为CASCADE模式,不同的删除模式会影响数据删除结果,说明如下:
– PROTECT 模式:如果删除的数据设有外键字段并且关联其他数据表的数据,就提示数据删除失败。
– SET_NULL模式:执行数据删除并把其他数据表的外键字段设为Null,外键字段必须将属性 Null 设为 True,否则提示异常。
– SET_DEFAULT 模式:执行数据删除并把其他数据表的外键字段设为默认值。
– SET 模式:执行数据删除并把其他数据表的外键字段关联其他数据。
– DO_NOTHING 模式,不做任何处理,删除结果由数据库的删除模式决定。 -
在终端执行数据迁移命令:python manage.py makemigrations
-
在终端执行数据迁移命令,生成相应的数据表
-
查看生成的两种表
- 查看index_personinfo表
- 查看index_vocation表
- 执行命令:PersonInfo.objects.get(id=1).delete()
- 删除成功,总共删除了2条数据,1条是index_personinfo表的记录,1条是index_vocation表的记录。
- 查看index_personinfo表,“李红利”记录已被删除
- 查看index_vocation表,级联的记录(外键name_id=1)已被删除



