Django 外键 关于,on_delete=models.CASCADE失效问题

如题
django小白,不知道具体如何描述,特地申请了一个账号
直接上图
这是我键的两张表,第二个表是第一个表的小弟,这一个很清楚
接着我插入一些数据 ps 我做的项目,里有注册和登录拦截等功能,所以插入数据我不是在终端直接插入的,而是在项目运行的时候在网页里插入然后存入数据库的,话不多说,看图
在这里插入图片描述
在这里插入图片描述
灰的部分都是一些测试的不用看,
然后问题来了
在这里插入图片描述
在这里插入图片描述
以上是我插入的一些数据,我不知道为什么底下的user_id对应着上面的user_number难道是因为我的索引有问题,然而这不是我最关心的,当我在终端输入如下
在这里插入图片描述
报错在这里插入图片描述
what?? 如题,级联删除失效,为什么?
而当我将子表中对应的小弟都删除后,再执行如上语句,却成功了?为什么?

请教了直系学姐,还有一个我忘记点了哪的百度,有一句很关键的话,我的这个操作是针对应用层的,不是对db ,如获至宝

表,我是在django键的,而我的测试,却是在终端测试的,结果似乎我的约束(on_delete)没起作用,
django操作和终端操作似乎有些不同??
当我在django里写在这里插入图片描述,然后查看数据库在这里插入图片描述完美,一晚上没白费。应用层和db层的操作要区别开来。

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: on_delete=models.cascadeDjango中ForeignKey字段的一个参数,表示当关联的对象被删除时,与之相关的对象也会被删除。例如,如果一个博客文章有一个ForeignKey字段指向作者,当作者被删除时,与之相关的所有博客文章也会被删除。这个参数可以保证数据的完整性和一致性。 ### 回答2: on_delete=models.cascadeDjango模型中的一个选项,用于指定在父模型对象被删除时如何处理与其相关的子模型对象。 cascade(级联)是其中一种可选的参数值,表示当父模型删除时,与之相关联的所有子模型对象也会被自动删除。简单说,如果一个父模型对象被删除,所有相关联的子模型对象也会随之被删除。 这种级联删除的机制可以确保数据库中的关联数据的完整性。例如,如果一个博客文章(父模型)被删除,所有相关的评论(子模型)也会被删除,避免了对未有任何意义的评论数据的保留。 需要注意的是,使用cascade选项时需要慎重考虑,确保逻辑上的合理性。因为级联删除会删除与父模型对象相关联的所有子模型对象,可能会导致意外的数据丢失。因此,在应用中,我们应该根据具体需求来选择使用cascade选项,权衡数据完整性和删除操作的需求。 为了更好地理解cascade的作用,以下是一个示例: 假设我们有两个模型:一个是作者(Author),另一个是书籍(Book)模型。作者可以书写多本书。 使用on_delete=models.cascade选项,在Author模型中设置外键,如: book = models.ForeignKey(Book, on_delete=models.CASCADE) 在这种情况下,如果我们删除一个作者对象,所有与该作者相关的书籍对象也会被自动删除。这有助于保持数据库中的数据完整性,确保没有与已删除作者相关联的无效书籍数据。 总之,on_delete=models.cascade选项提供了一种便捷的方式,确保在删除父模型对象时,与其相关联的子模型对象也能被自动删除,以保持数据的完整性。 ### 回答3: on_delete=models.cascadeDjango模型的一个属性,它的作用是在数据库中级联删除相关的对象。 假设有两个模型A和B,模型A中的一个字段与模型B建立了外键关系。当设置on_delete=models.cascade时,意味着当模型A中某个对象被删除时,与之相关的模型B中的对象也会被级联删除。 这一级联删除的操作是自动进行的,不需要手动操作。当执行删除操作时,Django会自动追踪外键关联,检查是否需要级联删除,如果需要则执行级联删除。 级联删除主要用于确保数据完整性,避免了数据关联的不一致。当某个主要对象被删除时,与之相关的其他对象也会被同时删除,防止了数据冗余和孤立。 例如,假设模型A是作者(Author),模型B是文章(Article),每个文章都属于一个作者。当设置on_delete=models.cascade时,如果某个作者被删除,与之关联的所有文章也会被同时从数据库中删除,以保持数据的一致性。 总结说,on_delete=models.cascade是一种级联删除的配置选项,它确保了数据库中相关对象之间的数据一致性。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值