首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

django 引用自身和on_delete参数

该模型使用引用自己本身。...如果对应那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用那条数据,那么就不能删除外那条数据。如果我们强行删除,Django就会报错。...、update时候,子表会将关联记录字段所在列设为null,所以注意在设计子表时不能设为not null; 为什么在django中可以是用不同约束去操作数据库呢。...比如 django 中 on_delete=CASCADE, 但是数据库约束是RESTRICT....在进行删除A表数据时,发现被约束着,使数据不能被删除,则django会先去删除约束B表数据,然后再来删除A表数据。

1.3K20

Django学习-第七讲:django常用字段、字段属性,和表关系、操作

1. django常用字段 1. AutoField 映射到数据库中是int类型,可以有自动增长特性。一般不需要使用这个类型,如果指定主键,那么模型会自动生成一个叫做id自动增长主键。...第一个参数是引用是哪个模型,第二个参数是在使用引用模型数据被删除了,这个字段该如何处理,比如有CASCADE、SET_NULL等。这里以一个实际案例来说明。...一个Category可以有多个文章,一个Article只能有一个Category,并且通过进行引用。...因此在底层,Django为Article表添加了一个属性名_id字段(比如author字段名称是author_id),这个字段是一个,记录着对应作者主键。...即只要这条数据引用那条数据,那么就不能删除外那条数据。 3.SET_NULL:设置为空。如果那条数据被删除了,那么在本条数据上就将这个字段设置为空。

3.9K30
您找到你想要的搜索结果了吗?
是的
没有找到

django在开发中取消约束实现

# 在setting设置 'OPTIONS': { "init_command": "SET foreign_key_checks = 0;", } 补充知识:django-给关系传值...,删除外关系 反查: 在表关系里 related_name = ‘反查name’,自己设置,django也会默认设置为class小写名字+_set , ex: book_set....(数据库字段名字room_number_id)值,将相对应值直接赋值给该字段      class_number = ClassNumber.object.get("id=1").room_number...那么”一”,Book反查是,Book.object.get(id=1).reply_set.all() # reply_set是设置related_name时,django自己设置 多对多: class...s.teacher.remove(x) return HttpResponse("ojbk") 以上这篇django实现在开发中取消约束就是小编分享给大家全部内容了,希望能给大家一个参考。

3.6K10

python Django 反向访问器冲突解决

我有两个继承一个基类Django模型: – Request – Inquiry – Analysis 请求有两个到内置用户模型。...“Analysis.assign_user”反向访问器与“Inquiry.assign_user”反向访问器冲突。...我读过所有内容说,设置related_name应该防止冲突,但我仍然得到相同错误。任何人都能想到为什么会发生这种情况?谢谢!...)s_requests_created’) 补充知识:django related_name禁用反向映射 官方文档处理办法: ?...直接将related_name赋值为加号或以加号结尾字符串,即可实现禁用反向映射 以上这篇python Django 反向访问器冲突解决就是小编分享给大家全部内容了,希望能给大家一个参考。

1.4K10

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

0904自我总结 django模型中有关系表删除相关设置 一.一对一 例如有Author、AuthorDetail两表 author = models.OneToOneField(to='Author...db_constraint=False, on_delete=models.CASCADE ) 1)关系字段放在AuthorDetail表中:作者删除详情删除,详情删除作者保留 2)作者找详情用 ...related_name(detail),详情找作者用 字段(author) 3)db_constraint断开表关联,on_delete规定逻辑关联删除动作,models.CASCADE级联删除...):出版社删除书不动,书删除没有任何影响 2)出版社找书用 related_name(books),书找出版社 字段(publish) 3)db_constraint断开表关联,on_delete...,反向找 字段related_name 3)db_constraint断开表关联,on_delete不存在(设置,本质在第三张表中设置,且一定是级联)

3K20

Django(ForeignKey)操作以及related_name作用

之前已经写过一篇关于Django文章,但是当时并没有介绍如何根据对数据操作,也就是如何通过主表查询子表或者通过子表查询主表信息 首先我定义了两个模型,一个是老师模型,一个是学生模型,...,并获取老师相关信息 返回一个teacher对象,接下来就是查询teacher相关联学生对象,在这里有一个需要注意点,django默认情况下每一个主表对象都有一个是属性,可以通过它查询到所有关于子表信息...migrate 从上图可以看到和之前_set操作效果是一样,这两个方法是相同,所以如果觉得比较麻烦的话,可以在定义主表时候,直接就给定义好名称使用related_name...上面的查询主要是通过主表查询子表信息 下面说一下如何通过子表查询主表相关信息,也就是查询一个学生所对应老师信息 首先需要先获取一个子表对象,那么就可以通过定义时候那个字段名获取关于主表信息了...比如我得到了一个student对象,然后我想要得到这个student对象对应主表teache中信息的话,就使用 student.teacher 获取,其中这个teacher就是在子表中定义字段

2K10

django序列化时使用真实值操作

展示: 一般情况下序列化得到内容只是id: ... { fields: { uat_date: "2015-07-25", statu: "CG", name: "慢赢优化",...方法: 我序列化是Content表,它含有一个关联是Module表,1对多 我要先序列化Module表,然后序列化Content表时候才可以使用到Module真实值 class ModuleManager...actual_key,要保证先序列化,如下依赖: class Content(models.Model): name = models.CharField(max_length=100) ......原生序列化serialize解析 在写接口时候,大家都离不开对query结果集序列化 嗯嗯嗯,一般我们都有DRF里面的序列化工具,但是django原生serialize你们有 用过吗??????...,这种方法并不常用 在有特定需要时候,使用这种django原生序列化,还是十分方便

1.8K10

数据库推荐使用9个理由

来源:www.jdon.com/49188 我经验告诉我,很多数据库(大多数我曾经使用包含时并不总是一件坏事。在这篇文章中,我想把重点放在为什么原因上。 为什么这是一个问题?...1.潜在数据完整性问题, 缺少明显问题是数据库不能强制进行引用完整性检查,如果在高一层没有正确处理,则可能会导致数据不一致(子行没有相应父行)。...2.表格关系不清晰 数据库中缺少另一个不太明显负面影响是,不了解该模式的人很难找到正确表并找出表关系。这可能会导致严重数据库查询和报告问题。 为什么数据库可以没有?...让我们来看看数据库可以没有原因。首先一个简短免责声明(因为文章引发了一些关于LinkedIn群体争议): 下面的理由绝不鼓励不要在数据库中使用约束。...这些框架可以自己创建数据库表,而总是创建。使用这些工具开发人员很少会干扰自动生成模式,并且不需要

2K10

数据库推荐使用 9 个理由

1.潜在数据完整性问题, 缺少明显问题是数据库不能强制进行引用完整性检查,如果在高一层没有正确处理,则可能会导致数据不一致(子行没有相应父行)。...2.表格关系不清晰 数据库中缺少另一个不太明显负面影响是,不了解该模式的人很难找到正确表并找出表关系。这可能会导致严重数据库查询和报告问题。 为什么数据库可以没有?...让我们来看看数据库可以没有原因。首先一个简短免责声明(因为文章引发了一些关于LinkedIn群体争议): 下面的理由绝不鼓励不要在数据库中使用约束。...1.性能 在表上拥有活动可以提高数据质量,但会影响插入、更新和删除操作性能。在这些任务之前,数据库需要检查它是否违反数据完整性。这就是为什么一些架构师和DBA完全放弃原因。...这些框架可以自己创建数据库表,而总是创建。使用这些工具开发人员很少会干扰自动生成模式,并且不需要

1.6K30

Django 2.2文档系列】Model on_delete参数用法

场景 我们用DjangoModel时,有时候需要关联。关联时,参数:on_delete几个配置选项到底是干嘛呢,你知道吗? 参数介绍 models.CASCADE 级联删除。...Django会模拟SQL约束行为,在删除此条数据时,同事删除外关联对象。...” models.PROTECT 防止删除引用对象。与上个恰恰相反,是防止关联数据被删除。 models.SET_NULL 设置关联内容为null。只有设置了null=True时可用。...当数据被删除时,被关联内容被设置为null。 models.SET_DEFAULT 将值设置为默认值。必须设置有默认值 。...models.SET()将SET()设置值作为值 ,如果传递了callable,则调用它结果。 DO_NOTHING采取行动。

1.9K10

Django——ContentType(与多个表建立关系)及ContentType-signals使用

可以看到,我们通过model_class就可以获取对应类。也就是说,今后,我们如果自己定义model如果有关联到這个ContentType上,我们就能找到对应model名称。...对于新鲜事这个功能来说就是使用GenericRelation来产生一个特殊,它不像models.ForeignKey那样,必须指定一个Model来作为它指向对象。...怎么从这张操作记录表中得到相应操作model呢,这就得用到fields.GenericForeignKey,它是一个特殊,可以指向任何Model实例,在这里就可以通过这个字段来指向类似Post...是再给上面的表增加一个,然后重新修改数据库么?显然是不能,一旦数据库被创建了,我们几乎很少再去修改数据,如果再给其添加额外字段,无疑会带来不必要麻烦。...总之,如果一个表与其他表有多个关系,我们可以通过ContentType来解决这种关联。

4.3K20

Django中基表创建、字段属性简介、脏数据概念、子序列化

db_table = 'xxx'指定该类数据库表单名字。当然如果指定也没关系,Django会自动默认按照一定规则生成数据模型对应数据库表名。...如两张表建立了一对一字段,在A表,那么先往B表写数据就更合理。...更合理) """ Django orm中外字段属性详解 在建表之前我们对外字段属性进行了解: 1)related_name在外中设置反向查询字段名:正向找字段名,反向找related_name...,作者详情一定没有 DO_NOTHING:不会被级联,假设A表依赖B表,B记录删除,A表字段不做任何处理 例子:作者被删了,作者书还存在,书还是该作者写;出版社没了,出版社出版书还在...子序列化使用方法及注意事项: 1)只能在序列化中使用 2)字段名必须是(正向反向都可以)字段,相对于自定义序列化外字段,自定义序列化字段不能参与反序列化,而子序列化必须为键名,子序列化字段写入数据库

4.3K30

Django(15)和表关系

大家好,又见面了,我是你们朋友全栈君。 删除操作 如果一个模型使用了。那么在对方那个模型被删掉后,该进行什么样操作。可以通过on_delete来指定。...可以指定类型如下: CASCADE:级联操作。如果对应那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用那条数据,那么就不能删除外那条数据。...DO_NOTHING:采取任何行为。一切全看数据库级别的约束。 注意:以上这些选项只是Django级别的,数据级别依旧是RESTRICT! 表关系 表之间关系都是通过来进行关联。...这个OneToOneField其实本质上就是一个,只不过这个有一个唯一约束(unique key),来实现一对一。 以后如果想要反向引用,那么是通过引用模型名字转换为小写形式进行访问。...这个中间表分别定义了两个引用到article和tag两张表主键。

2.1K40

Django ORM

目录 Django ORM ORM实操之数据库迁移 ORM实操之字段修改 ORM实操之数据增删改查 数据库同步 ORM创建表关系 Django请求生命周期流程图 路由匹配 无名分组 有名分组 反向解析...migrate # 执行完会在数据库中产生Django所需依赖表,自动创建 # 自己创建表user以'应用名_表名'形式创建,app01_user ✨✨指定id字段和主键等,ORM会自动创建...: 一对多、多对多、一对一,没关系暂且排外,下面演示如何通过ORM来创建确立表关系~ ORM创建字段位置: 一对多:创建在多一方 一堆一:创建在任何一方都可以,但是推荐创建在查询频率较高表中...多对多(两种方式): 自己创建第三张表 创建在任何一方都可以,但是推荐创建在查询频率较高 # 创建书籍表 出版者表 作者表 # 先写表基本结构,在考虑表关系如何写 # 书籍表 class...max_length=32) price = models.DecimalField(max_digits=8, decimal_places=2) # 总共8位 小数占2位 # 作者

4K10

关于“Python”核心知识点整理大全53

of the game, roughly...>, <Entry: In the opening phase of the game, it's important t...>] 为通过关系获取数据...例如, 假设你有模型Pizza和Topping,而Topping通过一个关联到Pizza;如果你有一个名为my_pizza 对象,表示一张比萨,就可使用代码my_pizza.topping_set.all...Django在urlpatterns中查找与请求URL字符串匹配正则表达式,因此正则表达 式定义了Django可查找模式。 我们来看看正则表达式r'^$'。...其他URL都与这个正则表达式匹配。如果请求URL不与任何URL模式匹配Django 将返回一个错误页面。 url()第二个实参(见5)指定了要调用视图函数。...请求URL与前述正则表达式匹配时, Django将调用views.index(这个视图函数将在下一节编写)。第三个实参将这个URL模式名称 指定为index,让我们能够在代码其他地方引用它。

9210
领券