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

django 模型关系

模型关系 关系数据库威力体现在表之间相互关联,Django提供了三种最常见数据库关系:多对一 (many-to-one),多对多(many-to-many),一对一(one-to-one)...多对一关系 多对多关系 一对一关系 多对一 django是使用django.db.models.ForeignKey 定义多对一关系 ForeignKey需要一个位置参数来指定本Model关联Model...,ForeignKey关联Model 是"一", ForeignKey所在Model是"多" 比如汽车和制造商例子,一辆汽车只能属于一个制造商,但是一个制造商有多辆汽车,这个关系,用Django...对象 反向查询( ForeignKey 指向模型查询ForeignKey 所在模型) 如果模型有一个ForeignKey,那么该ForeignKey 所指模型实例可以通过一个管理器返回前一个有ForeignKey...如果不仅仅需要知道两个Model之间是多对多关系,还需要知道这个关系更多信息,比如Person和Group是多对多关系,每个person可以在多个group里,那么group里可以有多个person

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

基于Django OneToOneField和ForeignKey区别详解

一般来说,一个模型对于数据库中一个表单。 字段(Fields)是模型重要和唯一组成部分,他们由类别的属性值所指定。...对于每个ForeignKey,我们需要给出关联模型和on_delete响应选项,即 manufacturer = models.ForeignKey( 'Manufacturer', on_delete...,后者表示“成员资格”,即表示“团体”与“个人”之间关系中间项,而“through_fields”字段即为中间项连接起来两个类名,此处即group和person两个类。...在概念上我们可以理解其为设置unique属性为True一种类型,区别之处在于它“反向”数值会返回一个目标值,这对于继承关系表达十分有用,例如一下示例程序: from django.conf import...以上这篇基于Django OneToOneField和ForeignKey区别详解就是小编分享给大家全部内容了,希望能给大家一个参考。

2.3K20

python-Django-Django 模型关联关系(一)

Django是一个流行Python Web框架,其模型层允许开发人员定义数据库模型以及它们之间关系。...这些关系被称为模型关联关系,允许开发人员在不同模型之间建立复杂关联关系,从而实现更高级别的数据结构。一对一关系一对一关系是指两个模型之间存在唯一对应关系。...一对多关系一对多关系是指一个模型可以对应多个另一个模型实例。在Django中,可以使用ForeignKey字段来定义一对多关系。...(Author, on_delete=models.CASCADE)在上面的代码中,Book模型定义了一个名为authorForeignKey字段,它指向另一个模型Author。...多对多关系多对多关系是指两个模型之间存在多个对应关系。在Django中,可以使用ManyToManyField字段来定义多对多关系

66410

Django基础篇-模型关系

一对多表关系 在 Mysql 中一对多是通过外键实现,在 django 模型中通过 ForeignKeyField 类型实现。...框架篇-Django博客应用-更新首页 一对一表关系 在 Mysql 中一对一是通过外键加唯一键实现,在 django 模型中通过 OneToOneField 类型实现。...多对多表关系 在 Mysql 中多对多是通过中间表外键加联合唯一键实现,在 django 模型中通过 ManyToManyField 类型实现。中间表模型会自动创建。...例子: 学院---学生---课程---学生成绩 学院与学生一对一关系,学生与课程多对多关系 课程 学生成绩 关系表中数据操作 : 同级目录下 views.py from django.http import...() # 多对多反向查询 print(cs.student_set.all()) return HttpResponse("查询数据成功")

84030

SQLAlchemy建立数据库模型之间关系

常见关系: 一对多关系 多对一关系 多对多关系 一对一关系 一对多关系(一个作者,多篇文章) ## 一对多关系,单作者-多文章,外键不可少 ## 外键(ForeignKey)总在多那边定义,关系(relationship...在关系出发侧定义 ## relationship()函数第一个参数为关系另一侧模型名称(Article) articles = db.relationship('Article')...参数形式为:"表名.字段名" ## 模型类对应表名由Flask-SQLAlchemy生成,默认为类名称小写形式,多个单词通过下划线分隔 author_id = db.Column(...db.Integer, db.ForeignKey('author.id')) # # 外键字段(author_id)和关系属性(articles)命名没有限制 ## 建立关系可通过操作关系属性进行...关联表不存储数据,只用来存储关系两侧模型外键对应关系 定义关系两侧关系函数时,需要添加一个secondary参数,值设为关联表名称 关联表由使用db.Table类定义,传入第一个参数为关联表名称

1.6K20

之间关系

简单说,类和类之间关系有三种:is-a、has-a和use-a关系。 is-a关系也叫继承或泛化,比如学生和人关系、手机和电子产品关系都属于继承关系。...has-a关系通常称之为关联,比如部门和员工关系,汽车和引擎关系都属于关联关系;关联关系如果是整体和部分关联,那么我们称之为聚合关系;如果整体进一步负责了部分生命周期(整体和部分是不可分割,同时同在也同时消亡...),那么这种就是最强关联关系,我们称之为合成关系。...use-a关系通常称之为依赖,比如司机有一个驾驶行为(方法),其中(参数)使用到了汽车,那么司机和汽车关系就是依赖关系

56530

.NET映射设计(Model与UIControl之间模型关系)

随着ORM流行和大面积使用,行业内出现各种各样ORM框架,有自己开发有大型软件公司开发,基本在使用上都遵循了以实体为中心概念,也就是围绕关系数据库中表为操作对象。...2:实体与界面的关系 大部分系统都是需要将数据展现在界面上,然后在从界面上安全搜集起来放到实体中进行增、删、改、查操作。...[王清培版权所有,转载请给出署名] 3:利用Model与UIControl之间模型扩展基础框架 从上面所讲问题,我们隐隐约约似乎明白点东西了。 我们先来看简单封装。...(可以参见我 “利用抽象、多态实现无反射绿色环保ORM框架”一文)从ORM角度讲提高了性能,从大一点角度讲可以借鉴领域驱动设计中Module划分和大比例结构,将实体进行抽象后会变很强大,如果能做到分层架构中合理表现领域模型那就是绝对厉害...[王清培版权所有,转载请给出署名] 我们看一下我写一个小示例: 图3: 实体图 这个实体属性很多,由于时间关系我只使用两个属性做演示。

58940

完美解决Django2.0中models下ForeignKey()问题

Django2.0中编写models类下ForeignKey book = models.ForeignKey(‘BookInfo’) django2.0与之前1.8不同, 错误: book...’ 解决方法: book = models.ForeignKey(‘BookInfo’, on_delete=models.CASCADE,) 加上on_delete参数就可以了!!!...补充知识:Django ForeignKey ondelete CASCADE:删除一并删除关联表下所有的信息; PROTECT:删除信息时,采取保护机制,抛出错误:即不删除关联表内容; SET_NULL...:只有当null=True才将关联内容置空; SET_DEFAULT:设置为默认值; SET( ):括号里可以是函数,设置为自己定义东西; DO_NOTHING:字面的意思,啥也不干,你删除你干我毛线关系...以上这篇完美解决Django2.0中models下ForeignKey()问题就是小编分享给大家全部内容了,希望能给大家一个参考。

75910

Django外键(ForeignKey)操作以及related_name作用

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

1.9K10

SQL表之间关系

SQL表之间关系要在表之间强制执行引用完整性,可以定义外键。修改包含外键约束表时,将检查外键约束。定义外键有几种方法可以在InterSystems SQL中定义外键:可以定义两个类之间关系。...定义关系会自动将外键约束投影到SQL。可以在类定义中添加显式外键定义(对于关系未涵盖情况)。可以使用CREATE TABLE或ALTER TABLE命令添加外键。...用作外键引用RowID字段必须是公共。引用隐藏RowID?有关如何使用公用(或专用)RowID字段定义表信息。一个表(类)外键最大数目为400。...默认情况下,当删除带有外键行时,InterSystems IRIS将在相应被引用表行上获取长期(直到事务结束)共享锁。这样可以防止在引用行上DELETE事务完成之前对引用行进行更新或删除。...在父/子关系中,没有定义子元素顺序。 应用程序代码不能依赖于任何特定顺序。父表和子表定义父表和子表在定义投射到表持久类时,可以使用relationship属性指定两个表之间父/子关系

2.4K10

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

0904自我总结 django模型中有外键关系表删除相关设置 一.一对一 例如有Author、AuthorDetail两表 author = models.OneToOneField(to='Author...3)db_constraint断开表关联,on_delete规定逻辑关联删除动作,models.CASCADE级联删除 二.一对多 例如Book、Publish两表 publish = models.ForeignKey...Book表中(多一方):出版社删除书外键不动,书删除没有任何影响 2)出版社找书用 外键related_name(books),书找出版社 外键字段(publish) 3)db_constraint..., models.CASCAD为级联关系,'SET_NULL'置空,SET_DEFAULT设为默认值 两者区别 models.SET关联表内容删了,关联相关内容不会删除 models.CASCAD关联表内容删了...,关联相关内容会删除 db_constraint关系断开后,但是不影响联表查询 四.多对多关系 例如Book、Author两表 authors = models.ManyToManyField(to=

3K20

Django 之 Models(Models 模型 & 数据表关系

欢迎阅读本专栏其他文章 Django 之路由篇 Django 之视图篇 Django 之模板篇 Models 模型 ORM --- ObjectRelationMap...子类 class 中所有属性对应表格中字段 字段类型都必须使用 modles.xxx 不能使用python中类型 在django中,Models 负责跟数据库交互 django连接数据库 自带默认数据库...使用 objects 属性操作数据库,objects 是模型中实际和数据库进行交互 Manager 类实例化对象 4....:在模型任意一边即可,使用OneToOneFieldadd 添加没有关系一边,直接实例化保存就可以 s = School() s.school_id = 2...使用ForeignKey 在多那一边,比如上边例子就是在Teacher表格里进行定义 add 跟一对一方法类似,通过create和new来添加 create:把属性都填满,然后不需要手动保存

2.3K87

对象与对象之间关系

对象与对象之间关系 标签:java基础 依赖关系 class Student { private List courses; } class Course { }...(Aggregation) 聚合关系表示整体与部分关系,是一种弱拥有关系。...组合关系表示整体与部分关系,是一种强拥有关系。...关联和聚合区别主要在语义上,关联两个对象之间一般是平等,例如你是我朋友,聚合则一般不是平等。 关联是一种结构化关系,指一种对象和另一种对象有联系。...聚合与组合 聚合与组合都是一种结合关系,只是额外具有整体-部分意涵。 部件生命周期不同 聚合关系中,整件不会拥有部件生命周期,所以整件销毁时,部件不会被销毁。

5610

binder,hwbinder,vndbinder之间关系

对于想要继续在供应商进程之间使用 AIDL 接口供应商,Android 会按以下方式支持 Binder IPC。...假如手机中有如下3类进程 a.应用进程: Camera APP 手电筒 APP b.框架进程: System Server进程 c.供应商进程: Camera HAL进程 Light HAL进程 这些进程之间需要使用...3 三种Binder介绍以及之间联系 3.1 dev/binder 这个是我们最熟悉Binder,App开发中,ActivityManagerService用都是这个,Java继承Binder,C...dev/binder或dev/vndbinder之间共存问题?...SDK->dev/hwbinder 5 总结 为什么Android团队要大费周章搞出那么多Binder,我觉得有以下几个原因: 1.可以发现App不可能直接跨过FWK调用HAL层接口,FWK和HAL之间接口也是安卓官方限定

1.3K30
领券