前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >django模型中有外键关系的表删除相关设置

django模型中有外键关系的表删除相关设置

作者头像
小小咸鱼YwY
发布2019-09-11 15:10:59
2.9K0
发布2019-09-11 15:10:59
举报
文章被收录于专栏:python-爬虫python-爬虫

0904自我总结

django模型中有外键关系的表删除相关设置

一.一对一

例如有Author、AuthorDetail两表

代码语言:javascript
复制
author = models.OneToOneField(to='Author', null=True,
        related_name='detail',
        db_constraint=False,
        on_delete=models.CASCADE
    )

1)关系字段放在AuthorDetail表中:作者删除详情删除,详情删除作者保留 2)作者找详情用 外键related_name(detail),详情找作者用 外键字段(author) 3)db_constraint断开表关联,on_delete规定逻辑关联删除动作,models.CASCADE级联删除

二.一对多

例如Book、Publish两表

代码语言:javascript
复制
publish = models.ForeignKey(to='Publish', null=True,
        related_name='books',
        db_constraint=False,
        on_delete=models.DO_NOTHING,
        
    )

1)关系字段放在Book表中(多的一方):出版社删除书外键不动,书删除没有任何影响 2)出版社找书用 外键related_name(books),书找出版社 外键字段(publish) 3)db_constraint断开表关联,on_delete规定逻辑关联删除动作,models.DO_NOTHING关联无动作

三.以外键字段关联

1)断关联,删除关联表记录,外键值置空 db_constraint=False, on_delete=models.SET_NULL, null=True,

2)断关联,删除关联表记录,外键值置默认值 db_constraint=False, on_delete=models.SET_DEFAULT, default=1,

注意:on_delete必须声明models.DO_NOTHING为删除级联关系, models.CASCAD为级联关系,'SET_NULL'置空,SET_DEFAULT设为默认值

两者区别

  • models.SET关联表内容删了,关联的相关内容不会删除
  • models.CASCAD关联表内容删了,关联的相关内容会删除

db_constraint关系断开后,但是不影响联表查询

四.多对多关系

例如Book、Author两表

代码语言:javascript
复制
authors = models.ManyToManyField(to='Author', null=True,
        related_name='books',
        db_constraint=False,
    )

1)关系字段放在任意一方都可以:出版社删除或书删除彼此不影响,但关系表一定级联删除 2)正向找 外键字段,反向找 外键字段related_name 3)db_constraint断开表关联,on_delete不存在(不设置,本质在第三张表中设置,且一定是级联)

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-09-04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 0904自我总结
  • django模型中有外键关系的表删除相关设置
    • 一.一对一
      • 二.一对多
        • 三.以外键字段关联
          • 四.多对多关系
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档