0904自我总结 django模型中有外键关系的表删除相关设置 一.一对一 例如有Author、AuthorDetail两表 author = models.OneToOneField(to='Author...related_name(detail),详情找作者用 外键字段(author) 3)db_constraint断开表关联,on_delete规定逻辑关联删除动作,models.CASCADE级联删除...,书删除没有任何影响 2)出版社找书用 外键related_name(books),书找出版社 外键字段(publish) 3)db_constraint断开表关联,on_delete规定逻辑关联删除动作...,models.DO_NOTHING关联无动作 三.以外键字段关联 1)断关联,删除关联表记录,外键值置空 db_constraint=False, on_delete=models.SET_NULL...,反向找 外键字段related_name 3)db_constraint断开表关联,on_delete不存在(不设置,本质在第三张表中设置,且一定是级联)
展示: 一般情况下序列化得到的外键的内容只是id: ... { fields: { uat_date: "2015-07-25", statu: "CG", name: "慢赢优化",...方法: 我序列化的是Content表,它含有一个外键关联的是Module表,1对多 我要先序列化Module表,然后序列化Content表的时候才可以使用到Module的真实值 class ModuleManager...jsons = serializers.serialize(‘json’, queryset,use_natural_foreign_keys=True) 附: 如果要给Content表序列化,那么要使用到外键的...actual_key,要保证外键先序列化,如下依赖: class Content(models.Model): name = models.CharField(max_length=100) ......django原生序列化,还是十分方便的
也就是说,今后,我们如果自己定义model如果有外键关联到這个ContentType上,我们就能找到对应的model名称。...对于新鲜事这个功能来说就是使用GenericRelation来产生一个特殊的外键,它不像models.ForeignKey那样,必须指定一个Model来作为它指向的对象。...是再给上面的表增加一个外键,然后重新修改数据库么?显然是不能,一旦数据库被创建了,我们几乎很少再去修改数据,如果再给其添加额外字段,无疑会带来不必要的麻烦。...null null # 两个都为空,说明全场都可以使用 #2 满100-10 1 null # 给学位课程创建优惠券 #3...总之,如果一个表与其他表有多个外键关系,我们可以通过ContentType来解决这种关联。
Django中想要把模型类聚合得到想要的数据可以用F对象。 比如有模型类A和B,A和B之间有外键关联在一起,A是子表,B是父表(反过来没试过。。...这样操作的结果就是可以查询到userid为3且模型类A字段bookid等于模型类B字段bid的集合数据了。 F对象是可以比较两个关联模型类的字段数据的。...我看到网上有说F对象可以这样用F(‘b__id’) == F(‘模型类名小写__字段名’),此处是双下划线。 但是我用Django2.0时会报错。。真是搞不懂,后来我直接使用字段名居然可以,醉了。...添加的是'模型类字段' # 如果是外键需要遵循这样的语法:本表外键字段__(双下划线)外检表字段或外检表的外键字段__最终外键表要显示的字段。...以上这篇使用Django实现把两个模型类的数据聚合在一起就是小编分享给大家的全部内容了,希望能给大家一个参考。
1、manage.py是Django项目通用的管理脚本(通过python manage.py 某命令参数使用)。...我们的WikiHome页面模型中需要图中红色高亮的一系列字段,其中title字段继承自Page类,不用额外添加,image字段为连接到wagtailimages.Image模型的外键。...WikiHomeTopLink类似,为了层次上更清晰,采用了多重继承,在models.py中只定义ParentalKey外键,而在另一个文件中定义了RelatedLink模型,包含的字段有链接文本和具体链接...,只是具体链接可能为外链、某个页面或某个文档,占用了三个字段,此外还利用@property装饰器为该模型添加了link属性,来返回它的具体链接,这样在模板中就可以使用.link调用。...它有一系列现成的layouts供我们使用,选择最适合本次主页的样式,查看源码可以得到详细的信息,在这里,为了简便,我们直接使用了该layout的额外样式表的链接(最好处理为本地的css样式文件,使用Django
如果未指定 max_length,则使用默认值200。 (21) UUIDField 用于存储通用唯一标识符的字段。使用Python的 UUID类。...在PostgreSQL上使用时,它存储在uuid数据类型中,否则存储在 中char(32)。 是通用的唯一标识符,可以很好的替代带有的 primary_key的AutoField字段。...如果需要在尚未定义的模型上创建关系,则可以使用模型的名称,而不是模型对象本身。...SET_NULL:删除时把外键置为null,当null=True时才可以使用。 SET_DEFAULT:把外键置为默认值,必须要设置默认值时才可以使用。...Django会自动创建中间的链接表来表示多对多的关系。
通过“迁移操作”(migrate)来添加模型。 用NoSQL来应对需要降低范式级别的场景。 如果布尔类型可以为空要使用NullBooleanField。 在模型中放置业务逻辑。...模型定义参考 字段 对字段名称的限制 字段名不能是Python的保留字,否则会导致语法错误 字段名不能有多个连续下划线,否则影响ORM查询操作 Django模型字段类 字段类 说明 AutoField...db_constraint:是否为外键创建约束,默认值为True。...on_delete:外键关联的对象被删除时对应的动作,可取的值包括django.db.models中定义的: CASCADE:级联删除。...SET_NULL:把外键设置为null,当null属性被设置为True时才能这么做。 SET_DEFAULT:把外键设置为默认值,提供了默认值才能这么做。
这里提供一个场景,网上商城购物时,会有各种各样的优惠券,比如通用优惠券,满减券,或者是仅限特定品类的优惠券。...在数据库中,可以通过外键将优惠券和不同品类的商品表关联起来: from django.db import models class Electrics(models.Model): """...但是这样做是有问题的:实际中商品品类繁多,而且很可能还会持续增加,那么优惠券表中的外键将越来越多,但是每条记录仅使用其中的一个或某几个外键字段。...contenttypes 应用 通过使用contenttypes 应用中提供的特殊字段GenericForeignKey,我们可以很好的解决这个问题。...通常这个字段命名为“object_id” 在model中定义GenericForeignKey字段,传入上述两个字段的名字。
之前已经写过一篇关于Django外键的文章,但是当时并没有介绍如何根据外键对数据的操作,也就是如何通过主表查询子表或者通过子表查询主表的信息 首先我定义了两个模型,一个是老师模型,一个是学生模型,...,并获取老师的相关信息 返回一个teacher对象,接下来就是查询teacher相关联的学生对象,在这里有一个需要注意的点,django默认情况下每一个主表的对象都有一个是外键的属性,可以通过它查询到所有关于子表的信息...,在models.py使用Foreign定义外键的时候也可以传入一个参数related_name,操作如下: 执行python manage.py makemigrations 和 python manage.py...migrate 从上图可以看到和之前的_set操作的效果是一样的,这两个方法是相同的,所以如果觉得比较麻烦的话,可以在定义主表的外键的时候,直接就给外键定义好名称使用related_name...比如我得到了一个student对象,然后我想要得到这个student对象对应的主表teache中的信息的话,就使用 student.teacher 获取,其中这个teacher就是在子表中定义的外键字段
目录 项目源码 安装 支持的 Django 版本/前提条件。 用法 模型变化 使用 mixins 更改模型 在 db 层自动化复合外键: 在哪里设置租户?...Ex: tenant_id='store_id' TenantModel 子类的所有外键都应使用 TenantForeignKey 代替 models.ForeignKey 实现上述 2 个步骤的示例模型...: 使用 mixins 更改模型 在您要使用库的任何文件中,只需: 所有模型都应使用 TenantModelMixin 和 django models.Model 或您的客户模型类 Ex: class...Ex: tenant_id='store_id' TenantModel 子类的所有外键都应使用 TenantForeignKey 代替 models.ForeignKey 实现上述 2 个步骤的示例模型...: 在 db 层自动化复合外键: 使用 TenantForeignKey 在租户相关模型之间创建外键将自动将 tenant_id 添加到引用查询(例如 product.purchases)和连接查询(例如
Django在admin站点中,自动地将所有的外键关系展示为一个select框。在我们的例子中,目前只有一个question对象存在。 请注意图中的绿色加号,它连接到Question模型。...每一个包含外键关系的对象都会有这个绿色加号。点击它,会弹出一个新增Question的表单,类似Question自己的添加表单。...填入相关信息点击保存后,Django自动将该Question保存在数据库,并作为当前Choice的关联外键对象。通俗讲就是,新建一个Question并作为当前Choice的外键。...你可以硬编码链接到指定对象的admin页面,使用任何你认为好的方法,用于替代这个app_list。...Part3-视图和模板 Django 1.10中文文档-第一个应用Part4-表单和通用视图 Django 1.10中文文档-第一个应用Part5-测试 Django 1.10中文文档
3、通用视图 django.views.generic.ListView和django.views.generic.edit下的CreateView, UpdateView, DeleteView都是通用视图...通用视图使用时,只需要承继后,再设置model或者form_class即可。...可以看到,除去定义model或者form类外,几行代码就可以搞定这么多事。我们看看CreateView的继承关系: 简单介绍下CreateView通用视图中每个父类的作用。...,此时是不能save的,因为外键project和address对应的数据库记录还没有创建,所以commit传为False contract = form.save(commit=False...里得到的表单 context = self.get_context_data() #按照四条数据库记录的顺序依次的创建(调用save方法)、主键赋到下一条记录的外键中
list_editable 设置默认可编辑字段 list_editable = ['machine_room_id', 'temperature'] #fk_fields 设置显示外键字段...过滤器如果是外键需要遵循这样的语法:本表字段__外键表要显示的字段。如:“user__user_name” 3、颜色显示 想对某些字段设置颜色,可用下面的设置: ?...例如,有两个模型,一个是订单主表(BillMain),记录主要信息;一个是订单明细(BillSub),记录购买商品的品种和数量等。...我们如何修改这个app的名称达到定制的要求呢,其实Django已经在文档里进行了说明。 从Django1.7以后不再使用app_label,修改app相关需要使用AppConfig。...例如两个字段相乘计算结果等等。这些都可以通过自定义列表字段处理和显示。 例如,两个模型Blog和Tag。多对多关系。简单模型代码如下: ?
最近博客在做新功能,就是增加了两个模型,分别是专题和主题,主要就是用来对文章进行系列划分,在这个设计过程中,文章和主题会进行一个关联,当主题的数量很多的时候,文章在选择要关联的主题的时候会非常难选。...['name', 'subject__name'] @admin.register(Article) class ArticleAdmin(admin.ModelAdmin): # 可以给外键的选择增加搜索...,前提是外键的管理模型必须设置search_fields作为搜索条件 autocomplete_fields = ['topic'] 看一下效果: 这里已经出现了搜索框,可以通过搜索条件来过滤选项...总结 本篇介绍了Django的admin.ModelAdmin中使用autocomplete_fields字段来给关联模型添加过滤搜索。...版权声明:如无特殊说明,文章均为本站原创,转载请注明出处 本文链接:https://tendcode.com/subject/article/django-admin-autocomplete_fields
外键删除操作 如果一个模型使用了外键。那么在对方那个模型被删掉后,该进行什么样的操作。可以通过on_delete来指定。可以指定的类型如下: CASCADE:级联操作。...注意:以上这些选项只是Django级别的,数据级别依旧是RESTRICT! 表关系 表之间的关系都是通过外键来进行关联的。而表之间的关系,无非就是三种关系:一对一、一对多、多对多等。...这个OneToOneField其实本质上就是一个外键,只不过这个外键有一个唯一约束(unique key),来实现一对一。 以后如果想要反向引用,那么是通过引用的模型的名字转换为小写的形式进行访问。...并且FrontUser对象可以使用userextension来访问对应的UserExtension对象。 如果不想使用Django默认的引用属性名字。...这个中间表分别定义了两个外键,引用到article和tag两张表的主键。
本章知识点 1、Django模型关系字段介绍与使用 2、Django模型关系字段查询 知识点讲解 1、Django模型关系字段介绍与使用 业务主体间的关系 学生 和 专业 关系 一个学生对应一个专业...一个专业对应多个学生 一对多关系 Foreignkey 外键 查询这个学生对应的专业 查询这个专业所有学生 学生 和 老师的关系 一个学生对应多个老师 一个老师对应多个学生 多对多关系...ManyToManyField 一个老师教过的所有学员 一个学员所有的老师 外键 专业 一 学生 多 外键字段 对应 专业表的主键 我们研究这两种关系,从以下的两个角度 1、...模型关系字段查询 1、外键 查询学生对应的项目 这样的查询时候最简单的,学生当中外键字段对应的就是外键的完整信息,可以直接获取 项目对应的所有学生 视图部分 前端部分...2、多对多数据 老师和学生 老师对应所有学生 学生对应的所有老师 本章总结 Django模型关系字段介绍与使用 Django模型关系字段查询
类型,CharField对应数据库的varchar类型,DecimalField对应数据库的decimal类型,ForeignKey用来建立多对一外键关联。...,可以为Dept和Emp两个模型类添加__str__魔法方法。...db_constraint:是否为外键创建约束,默认值为True。...on_delete:外键关联的对象被删除时对应的动作,可取的值包括django.db.models中定义的: CASCADE:级联删除。...SET_NULL:把外键设置为null,当null属性被设置为True时才能这么做。 SET_DEFAULT:把外键设置为默认值,提供了默认值才能这么做。
,要显式指定外键并关联到多对多关系涉及的模型。...中介模型有一些限制: 中介模型必须有且只有一个外键到源模型(上面例子中的Group),或者你必须使用ManyToManyField.through_fields 显式指定Django 应该使用的外键。...对于通过中介模型与自己进行多对多关联的模型,允许存在到同一个模型的两个外键,但它们将被作为多对多关联关系的两个(不同的)方面。...如果有超过 两个外键,同样你必须像上面一样指定through_fields,否则将引发一个验证错误。...Changed in Django 1.7: 在Django 1.6 及之前的版本中,中介模型禁止包含多于一个的外键。
0x00 模型 当前项目的开发, 都是数据驱动的 使用Django进行数据库开发的提示 : MVT设计模式中的Model, 专门负责和数据库交互.对应(models.py) 由于Model中内嵌了ORM...框架, 所以不需要直接面向数据库编程 而是定义模型类, 通过模型类和对象完成数据库表的增删改查 ORM框架就是把数据库表的行与相应的对象建立关联, 互相转换.使得数据库的操作面向对象 使用Django进行数据库开发的步骤...… TypeError: __init__() missing 1 required positional argument: 'on_delete' 在运行第一个命令的时候报错了,此时只需要修改定义外键的那行代码即可...1.8版本的Django,而我安装的是3.0,Django在2.0版本后,如果定义外键就需要加上on_delete选项了,OK,接下来,继续运行这两个代码。...使用django站点管理模块步骤: 管理界面本地化 创建管理员 注册模型类 自定义站点管理界面 1、管理界面本地化 将语言,时间设置为本地的语言时间,大陆使用的简体中文,时区使用亚洲/上海时区,修改settings.py
重点内容回顾-DRF 1. on_delete on_delete是定义模型类中外键的一个选项。 on_delete选项指明的是主表删除数据的时候,对于外键引用的表数据如何处理。...b.PROTECT保护,通过抛出一个异常ProtectedError异常,来阻止删除主表中被外键引用的数据。...c.SET_NULL设置为 NULL,代表的是主表删除数据的时候,将外键关联的表数据设置为NULL。仅仅在该字段null=True,允许为null时可用。...2. related_name related_name是在定义模型类时,外键的一个选项。它的功能下面慢慢给大家分析一下。...5.3序列化&反序列化 下面从我们最近推文的项目来简单的理解两个概念。 序列化:将模型对象转换为字典或者json数据的过程。 反序列化:将前端传递的数据保存到模型对象中的过程。
领取专属 10元无门槛券
手把手带您无忧上云