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

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在开发中取消约束实现

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

3.6K10

python Django 反向访问器冲突解决

我有两个继承一个基类Django模型: – Request – Inquiry – Analysis 请求有两个到内置用户模型。...related_name将确保字段不会彼此冲突,但您有两个模型,每个模型都有这两个字段。...你需要把每个具体模型名字,你可以做一些特殊 string substitution: create_user = models.ForeignKey(User, related_name=’%(class...)s_requests_created’) 补充知识:django related_name禁用反向映射 官方文档处理办法: ?...直接将related_name赋值为加号或以加号结尾字符串,即可实现禁用反向映射 以上这篇python Django 反向访问器冲突解决就是小编分享给大家全部内容了,希望能给大家一个参考。

1.4K10

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

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

场景 我们用DjangoModel时,有时候需要关联。关联时,参数:on_delete几个配置选项到底是干嘛呢,你知道吗? 参数介绍 models.CASCADE 级联删除。...Django会模拟SQL约束行为,在删除此条数据时,同事删除外关联对象。...比如:用户有一个关联是用户健康记录表,当用户删除时,配置了这个参数健康记录表中跟这个用户有关数据也会被删除。...当数据被删除时,被关联内容被设置为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表写数据就更合理。...假设图书管理系统中书、出版社、作者、作者详细信息四张表之间关系如下: """ 表关系 1)Book 和 Publish 一对多:在多一方 Book 2)Book 和 Author 多对多:在查询频率高一方...更合理) """ Django orm中外字段属性详解 在建表之前我们对外字段属性进行了解: 1)related_name在外中设置反向查询字段名:正向找字段名,反向找related_name...,作者详情一定没有 DO_NOTHING:不会被级联,假设A表依赖B表,B记录删除,A表字段不做任何处理 例子:作者被删了,作者书还存在,书还是该作者写;出版社没了,出版社出版书还在

4.3K30

Django模型

Django模型 Django模型定义在models.py文件中。模型是MVT中M,也相当于MVC中M。 在Django中,模型必须继承自Model类。... 这个东西,通常都是在业务逻辑层面来实现,而不是在数据库中实现。但是通常大家学习数据库课程中,都会有数据库设计范式,其中有个第三范式就是专指约束。在这里只是简单介绍一下。...下面是另外一个模型,和前面的BookInfo模型通过关联起来。...:通过使用models.ForeignKey来设置,ForeignKey第一个参数是要关联模型类名,第二个参数是on_delete。...它常用值可以如下: CASCADE级联,删除主表数据时连通一起删除外表中数据 PROTECT保护,通过抛出ProtectedError异常,来阻止删除主表中被应用数据 SET_NULL设置为NULL

1.9K20

django 字段类型_access数据库类型是

**注意:**在模型中使用FileField或ImageField时,需要执行以下几个步骤: l 在settings.py中定义MEDIA_ROOT为django设置存储上载文件目录完整路径(这些文件并未直接存储在数据库中...(15) ImageField 继承FileField所有的方法,但还验证上传对象为有效图像。除了 可用于特殊属性FileField,一个ImageField也具有height和width 属性。...默认表单格式为TextInput。 (18) TextField 文本字段。默认表单小部件是Textarea,如果指定max_length属性,将反映在Textarea自动生成表单字段中。...如果需要在尚未定义模型上创建关系,则可以使用模型名称,而不是模型对象本身。...SET_NULL:删除时把置为null,当null=True时才可以使用。 SET_DEFAULT:把置为默认值,必须要设置默认值时才可以使用。

3.8K30

django中ModelForm多表单组合解决方案

所以,基本表单功能看BaseForm已经足够了。 2、从模型创建表单 django对于MVC中C与M间映射是非常体贴,集中体现中Model模型中(比如模型权限与用户认证)。...比如CreateView就会由django自动把页面上POST出form数据解析到model生成表单(或者form_calss指定ModelForm类型表单),同时调用表单save方法将数据添加到模型对应数据库表中...此时是不能save,因为project和address对应数据库记录还没有创建,所以commit传为False           contract = form.save(commit=False...#按照四条数据库记录顺序依次创建(调用save方法)、主键赋到下一条记录中、下一次记录创建(save)           projectAddress = context['projectAddressForm...'].save()           #从项目表单中获取到模型,先把地址id赋到外上再保存           project = context['projectForm'].save(commit

3.4K20

Django实战篇-论坛注册视图

在前两节中,完成了论坛模型创建和表单 forms 创建。 在模型层中用到字段类型,有整型,字符串型,时间型还有就是关联。...Django基础篇-模型基础 ① 在论坛注册中,需要创建注册函数; Django 自带了登录和注销视图类。...因为登录是需要传递数据,所以为 POST 请求,接下来就是实例化注册验证表单 SignUpForm(),将 request.POST 写入,是为了将前端传来数据转成 form 表单。...经过 form.is_valid() 字段验证,完成 form 表单中所填字段是否为注册表单SignUpForm() 对应字段类型和字段要求。...② 注册表单验证 SignUpForm() from django import forms from django.contrib.auth.forms import UserCreationForm

80120

Django 学习笔记之模型高级用法(上)

而细节用法往往体现在一些差别用法,难以理解知识点上。 1 复杂字段类型 经过前面的学习,我们知道模型字段类型一方面是指定数据库表列名称和数据类型,另一方面决定 HTML 中表单标签类型。...2.1 ForeignKey 1) on_delete 在 Django 2.0 中,设置时需要添加一个 on_delete选项。本身涉及到两个表数据,况且在数据库中是有约束行为。...SET_DEFAULT: 置默认值,删除时候,字段设置为默认值,所以定义时候注意加上一个默认值。 SET(): 自定义对应实体值。...2)limit_choices_to 该参数用于限制所能关联对象,只能用于 Django ModelForm(Django表单模块)和 admin 后台,对其它场合无限制功能。...4) related_name 用于关联对象反向引用模型名称。主要用于反向查询,即模型实例通过管理器返回第一个模型所有实例。

2K30

Django 1.10中文文档-第一个应用Part7-自定义管理站点

自定义管理表单 通过admin.site.register(Question)注册了Question后,Django可以自动构建一个默认表单。如果您需要自定义管理表单外观和功能。...在这个表单中,Question字段是一个select选择框,包含了当前数据库中所有的Question实例。Django在admin站点中,自动地将所有的关系展示为一个select框。...在我们例子中,目前只有一个question对象存在。 请注意图中绿色加号,它连接到Question模型。每一个包含关系对象都会有这个绿色加号。...点击它,会弹出一个新增Question表单,类似Question自己添加表单。填入相关信息点击保存后,Django自动将该Question保存在数据库,并作为当前Choice关联对象。...通俗讲就是,新建一个Question并作为当前Choice。 但是,实话说,这种创建方式效率不怎么样。

3.6K60

Django 1.10中文文档-第一个应用Part2-模型和管理站点

在这个例子中,我们只为Question.pub_date定义了一个通俗名称。对于此模型所有其他字段,该字段机器可读名称将足以作为其通俗名称。 有些Field类具有必需参数。...(你也可以重写这个行为); 按照惯例,Django会在外字段名后面添加 "_id"。(你依然可以重写这个行为); 关系由FOREIGN KEY约束显式声明。...不用在意DEFERRABLE部分;它只是告诉PostgreSQL直到事务最后再执行关联; 这些SQL语句是针对你所使用数据库定制,所以会为你自动处理某些数据库所特有的字段例如auto_increment...连表操作可以无限多级,一层一层连接。 # 下面是查询所有的Choices,它所对应Question发布日期是今年。...这里需要注意是: 这个表单是根据Question模型文件自动生成; 模型中不同类型字段(DateTimeField、CharField)会对应相应HTML输入控件。

2.3K60

Python面试题:Django Web框架基础与进阶

数据库操作:ORM:描述Django ORM基本使用,包括定义模型、执行CRUD操作、查询过滤等。数据库迁移:解释Django数据库迁移机制,演示如何创建、应用、回滚迁移。...表单与验证:表单类:阐述Django表单定义、字段类型、验证规则、绑定数据、清洗数据等过程。自定义验证:演示如何为表单字段添加自定义验证方法,处理复杂验证逻辑。...用户认证与授权:认证系统:描述Django自带认证系统,包括用户模型、登录/登出、密码管理等。权限与组:解释Django权限系统,演示如何为用户分配权限、创建用户组,以及在视图中进行权限检查。...三、易错点与规避策略忽视模型与数据库设计:误区:在设计模型时,忽视数据库范式、索引优化、数据冗余等问题。规避:遵循数据库设计原则,合理使用、多对多关系、索引,避免数据冗余。...定义Django模型from django.db import modelsclass User(models.Model): username = models.CharField(max_length

16010
领券