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

Django(15)关系

大家好,又见面了,我是你们朋友全栈君。 删除操作 如果一个模型使用了。那么在对方那个模型被删掉后,该进行什么样操作。可以通过on_delete来指定。...可以指定类型如下: CASCADE:级联操作。如果对应那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用了那条数据,那么就不能删除外那条数据。...如果那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。 SET():如果那条数据被删除了。...注意:以上这些选项只是Django级别的,数据级别依旧是RESTRICT! 关系 之间关系都是通过来进行关联。而之间关系,无非就是三种关系:一对一、一对多、多对多等。...这个中间分别定义了两个,引用到article和tag两张主键。

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

sqlserver语句创建表格_创建sql语句

今天介绍一下如何使用SQL Server语句创建并添加数据 首先先了解一下模式,在数据库中根据模式进行分组避免名称冲突 在SQL Server 2014中直接新建是默认前缀dbo 而命名其他模式需要使用...SQL Server语句进行创建 下面将一步一步进行演示,首先是创建一个数据库 然后创建模式在后面使用 根据创建模式或者使用默认模式名,进行创建,语句如下图 下面解释一下句子意思 看一下新建好...后面介绍如何在新表里面添加数据 根据列数和对应数据类型在括号中一一对应添加数据并使用逗号隔开 注意,以上添加数据方法需要同时添加全部字段 如果需要添加单个字段或者较多且不是全部字段则方法如下...当添加不是全部字段时注意不能为空字段必须写入数据 最后看一下添加好数据 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/183704.html原文链接:https

2.2K10

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

0904自我总结 django模型中有关系删除相关设置 一.一对一 例如有Author、AuthorDetail两 author = models.OneToOneField(to='Author...:作者删除详情删除,详情删除作者保留 2)作者找详情用 related_name(detail),详情找作者用 字段(author) 3)db_constraint断开关联,on_delete...(多一方):出版社删除书不动,书删除没有任何影响 2)出版社找书用 related_name(books),书找出版社 字段(publish) 3)db_constraint断开关联...,关联相关内容不会删除 models.CASCAD关联内容删了,关联相关内容会删除 db_constraint关系断开后,但是不影响联查询 四.多对多关系 例如Book、Author两 authors...2)正向找 字段,反向找 字段related_name 3)db_constraint断开关联,on_delete不存在(不设置,本质在第三张中设置,且一定是级联)

3K20

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

因此如果再使用null=True,Django会产生两种空值情形(NULL或者空字符串)。如果想要在表单验证时候允许这个字符串为空,那么建议使用blank=True。...关系 在MySQL中,有两种引擎,一种是InnoDB,另外一种是myisam。如果使用是InnoDB引擎,是支持约束存在使得ORM框架在处理关系时候异常强大。...因此这里我们首先来介绍下Django使用。 类定义为class ForeignKey(to,on_delete,**options)。...因此在底层,Django为Article添加了一个属性名_id字段(比如author字段名称是author_id),这个字段是一个,记录着对应作者主键。...即只要这条数据引用了那条数据,那么就不能删除外那条数据。 3.SET_NULL:设置为空。如果那条数据被删除了,那么在本条数据上就将这个字段设置为空。

3.9K30

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

Django中基设置 通过图书管理系统引入多表操作:如果我们创建方式是先抽象出之间相同字段建一个父类,然后在用每个类去继承这个父类,如下面的代码,我们将无法得到期望表字段。...db_table = 'xxx'指定该类数据库表单名字。当然如果不指定也没关系,Django会自动默认按照一定规则生成数据模型对应数据库名。...假设图书管理系统中书、出版社、作者、作者详细信息四张之间关系如下: """ 关系 1)Book 和 Publish 一对多:在多一方 Book 2)Book 和 Author 多对多:在查询频率高一方...更合理) """ Django orm中外字段属性详解 在建之前我们对外字段属性进行了解: 1)related_name在外中设置反向查询字段名:正向找字段名,反向找related_name...,作者详情一定没有 DO_NOTHING:不会被级联,假设A依赖B,B记录删除,A字段不做任何处理 例子:作者被删了,作者书还存在,书还是该作者写;出版社没了,出版社出版书还在

4.3K30

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

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

4.3K20

Django用户创建(四)

正常情况我们如果操作数据库需要: 创建数据库,设计结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行数据库操作 Django采用ORM形式完成数据库操作...:(在django中,根据代码中类自动生成数据库也叫--code first) ORM:Object Relational Mapping(关系对象映射) 类名对应------》数据库中名 类属性对应...以后修改,不会修改这个值 我们复制其中username和email再稍加整改 突然先到我们好像缺少了创建时间,更新时间。而且这两个内容在全部中都可以被应用到。所以我们封装一个基类好了。...ModelBase abstract = True 所以我们用户model文件就是: from django.db import models from utils.models...数据库展示 以上就完成了用户创建,不过里面的一些约束条件什么感觉还是有点问题,但是应该不影响正常使用(无法应对破坏性测试)。

2.1K60

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

1.4K10

mysql如何添加一个

1:创建一个父,主键作为子表: 1 create table province( 2 pId int primary key auto_increment, 3 pName varchar...(20) 4 ); 2:创建子表,是父主键: 1 create table user( 2 userId int primary key auto_increment, 3 userName varchar...(40), 4 pid int, 5 foreign key(pid) references province(pId) 6 ); 给一张添加,即给子表添加主键规则: 在子表声明一个字段pid...int,用于作为子表,foreign key(子表字段) references 父名(父主键字段名); 3:当创建好数据时添加约束: alter table user add...foreign key(pid) references province(pId); alter table 子表数据名 add foreign key(子表键名称) references 父数据名称

4.3K70

django操作非ORM创建

django--ORM连接已存在 问题: djangoORM怎么连接已存在,然后进行增删查改操作?...工作中会遇见很多二次开发时候,都是已经创建,用djangoORM进行二次开发,怎么操作数据库中呢?...会报错找不到app_tencent_depth这个,而我名为tencent_depth djangoORM连接时候,会自动在前面加上应用名(app_),就是创建应用时起名字 第二次尝试:...虽然可以用djangoORM连接了,但是却改了名  (线上环境中,之间肯定有很多关联), 不能这么做 完美解决方案: 既然不能改tencent_depth名字,那么让djangoorm...添加字段,添加记录,获取数据都没有问题,完美解决djangoORM操作已存在问题

1.6K20

Django(ForeignKey)操作以及related_name作用

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

1.9K10

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...原生序列化serialize解析 在写接口时候,大家都离不开对query结果集序列化 嗯嗯嗯,一般我们都有DRF里面的序列化工具,但是django原生serialize你们有 用过吗??????...,这种方法并不常用 在有特定需要时候,使用这种django原生序列化,还是十分方便

1.8K10
领券