Django中基表的设置 通过图书管理系统引入多表操作:如果我们创建表的方式是先抽象出表与表之间相同的字段建一个父类,然后在用每个表类去继承这个父类,如下面的代码,我们将无法得到期望的表字段。...更合理) """ Django orm中外键字段属性详解 在建表之前我们对外键字段属性进行了解: 1)related_name在外键中设置外键反向查询的字段名:正向找字段名,反向找related_name...SET_DEFAULT:假设A表依赖B表,B记录删除,A表的外键字段重置为default属性设置的值,所以必须配合default属性使用。...子序列化的使用方法及注意事项: 1)只能在序列化中使用 2)字段名必须是外键(正向反向都可以)字段,相对于自定义序列化外键字段,自定义序列化字段不能参与反序列化,而子序列化必须为外键名,子序列化字段不写入数据库...3)如果外键关联的表有多个字段时,需要设置子序列化字段many=True。 4)子序列化是单向操作,因为作为子系列的类必须写在上方,所以不能产生逆方向的子序列化。
第一个参数是引用的是哪个模型,第二个参数是在使用外键引用的模型数据被删除了,这个字段该如何处理,比如有CASCADE、SET_NULL等。这里以一个实际案例来说明。...因此在底层,Django为Article表添加了一个属性名_id的字段(比如author的字段名称是author_id),这个字段是一个外键,记录着对应的作者的主键。...即只要这条数据引用了外键的那条数据,那么就不能删除外键的那条数据。 3.SET_NULL:设置为空。如果外键的那条数据被删除了,那么在本条数据上就将这个字段设置为空。...如果设置这个选项,前提是要指定这个字段可以为空。 4.SET_DEFAULT:设置默认值。如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。...如果设置这个选项,前提是要指定这个字段一个默认值。 5.SET():如果外键的那条数据被删除了。那么将会获取SET函数中的值来作为这个外键的值。
展示: 一般情况下序列化得到的外键的内容只是id: ... { fields: { uat_date: "2015-07-25", statu: "CG", name: "慢赢优化",...序列化时得到外键的真实值: ... { fields: { uat_date: "2015-07-25", statu: "CG", name: "慢赢优化", tester:...方法: 我序列化的是Content表,它含有一个外键关联的是Module表,1对多 我要先序列化Module表,然后序列化Content表的时候才可以使用到Module的真实值 class ModuleManager...actual_key,要保证外键先序列化,如下依赖: class Content(models.Model): name = models.CharField(max_length=100) ......,这种方法并不常用 在有特定需要的时候,使用这种django原生序列化,还是十分方便的
会自动将该外键的行数据以str()化之后进行搜索,但其实并不是这样的,如果将外键加入到搜索域中,需要明确写出来。...“related Field has invalid lookup: icontains”错误,主要原因是外键查询是需要指定相应的字段的。...外键不应该只是一个model,而该是另一个表的明确的一个字段。 所以我们需要指定特定的字段 “本表外键字段__外键所在表需查询字段”。...补充知识:Django的model中使用外键,但在页面上显示的是xxx_object?...admin中配置搜索域是一个外键时的处理方法就是小编分享给大家的全部内容了,希望能给大家一个参考。
它会暴露所有可能的操作作为方法,这些方法应该按照执行修改的顺序调用。可能一些操作或者类型并不可用于所有数据库 – 例如,MyISAM引擎不支持外键约束。...如果字段为ManyToManyField并且缺少 through值,会创建一个表来表示关系,而不是创建一列。如果提供了through值,就什么也不做。...如果字段为ForeignKey,同时会向列上添加一个外键约束。...外键约束,或者索引。...如果字段是ManyToManyField并且缺少through值,会移除创建用来跟踪关系的表。如果提供了through值,就什么也不做。
目录 Django ORM 多表操作 表模型 表关系 创建模型 逆向到表模型 插入数据 ORM 添加数据(添加外键) 一对多(外键 ForeignKey) 一对一 (OneToOneFeild) 多对多...ORM 多表操作 表模型 图书表 出版社表 作者表 作者详情表 表关系 一对一:一对一推荐建在查询频率高的一方 一对多:外键字段建在多的一方 多对多:外键字段建在查询频率多的一方,在Django第三张表不需要创建...,自动创建 ps:外键字段不需要写表名_id后面的_id,ORM创建的时候自动添加了_id,以及外键以虚拟字段的形式存在 创建模型 '''models.py''' from django.db import...6、若有模型类存在外键,创建数据时,要先创建外键关联的模型类的数据,不然创建包含外键的模型类的数据时,外键的关联模型类的数据会找不到 逆向到表模型 插入数据 ps:插入几条数据方便操作 ORM...(常用) 一对多中,设置外键属性的类(多的表)中,MySQL 中显示的字段名是:外键属性名_id。
Django&DRF重点内容大盘点 本文只是将学习过程中需要深刻记忆,在工作中常用的一些命令或者知识点进行一个罗列并阐释,不会全面的将所有内容进行讲解。...1.Django 1.1创建Django项目 这一命令必须熟记于心: django-admin startproject 项目名 1.2 创建子应用 1.在工作中我们要开发很多项目,肯定需要很多模块,创建子应用肯定也需要掌握..., verbose_name='图书') # 外键 cascade是级联,删除主表数据时连同外键表中数据一起删除 1.12.3迁移生成表 1)生成迁移文件 python manage.py makemigrations...多对象.外键属性 例:hero.hbook 2....(heroinfo__hcomment__contains='八') 查英雄(多) 多类.objects.filter(外键属性__字段__条件=值) 例:heros
在Django中具体的对应方式为: 类名对应数据库中的表名 类名对应数据库中的表名 类属性对应数据库里的字段 类实例对应数据库表里的一行数据 类实例对象的属性对应这行中的字段的值 一.数据库的连接 Django...这里的id是自动创建的,school_id是school添加外键产生的 如果想要与另一张表的其他字段添加外键,需要在加上参数to_filed=’字段名’,同时这个字段必须是unique=True 2.一对一...表示多对多的关系。 除了这种方式也可以手动创建一个表,手动添加两个外键来实现多对多。...,那么还可以直接添加该表的字段,利用两个外键的方式添加。...使用’__’进行的查找 一对多 school_name为外键对象的字段 school为student表中设置的外键字段 student1=student.objects.filter(id=2).values
大家好,又见面了,我是你们的朋友全栈君。 字段类型 字段类型指使用Django ORM创建数据库时支持的数据字段类型。...常用字段 (1) AutoField 自增的整型字段,必填参数primary_key=True,则成为数据库的主键,无该字段时,django会自动创建主键id字段。...是通用的唯一标识符,可以很好的替代带有的 primary_key的AutoField字段。...SET_NULL:删除时把外键置为null,当null=True时才可以使用。 SET_DEFAULT:把外键置为默认值,必须要设置默认值时才可以使用。...Django会自动创建中间的链接表来表示多对多的关系。
django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...外键 外键这个东西,通常都是在业务逻辑层面来实现的,而不是在数据库中实现。但是通常大家学习的数据库课程中,都会有数据库设计范式,其中有个第三范式就是专指的外键约束。在这里只是简单的介绍一下。...下面是另外一个模型,和前面的BookInfo模型通过外键关联起来。...外键:通过使用models.ForeignKey来设置外键,ForeignKey的第一个参数是要关联的模型类名,第二个参数是on_delete。...,此选项会抛出IntegrityError异常 注意:我们在数据库中,设置外键的时候需要制定另一张表中关联的字段,但是在Django里并没有指定。
2.项目创建 创建项目: django-admin startproject 项目名 创建子应用: python manage.py startapp 子应用 子应用首先到settings配置文件INSTALLED_APPS...return HttpResponse('hello world') 2.1.2url地址配置 1.先在子应用中创建urls.py文件,设置当前子应用中url地址和视图的对应关系。...class Meta: db_table = '' 定义外键属性: # 表中外键字段名格式: hbook = models.ForeignKey('BookInfo...() # 由多查1 多对象.外键属性 例:hero.hbook 2.通过模型类进行关联查询 # 查图书(一) 一类.objects.get|filter(多类名__字段__条件=值) 例:books =...BookInfo.objects.filter(heroinfo__hcomment__contains='八') # 查英雄(多) 多类.objects.filter(外键属性__字段__条件=值)
文章目录 一、模型类的定义 1.字段及参数 二、数据库配置 三、模型迁移 (建表) 四、单独的py文件测试ORM操作需要配置的参数 ---- 一、模型类的定义 代码如下: from django.db...import models # Create your models here. # 准备书籍列表信息的模型类 class BookInfo(models.Model): # 创建字段,字段类型...(max_length=10) gender = models.BooleanField() # 外键约束:人物属于哪本书 book = models.ForeignKey(BookInfo...EmailField:带有检查Email合法性的 CharField,不接受 maxlength 参数....ForeignKey:外键字段,设置在 '一对多’中’多’的一方; OneToOneField:一对一字段,用来扩展已有字段 ManyToManyFiled:多对多字段,建议设置在查询频率较高的表中 二
2) 关于主键 django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。...不指定时Django会自动创建属性名为id的自动增长属性 BooleanField 布尔字段,值为True或False NullBooleanField 支持Null、True、False三种值 CharField...默认值是False db_column 字段的名称,如果未指定,则使用属性的名称 db_index 若值为True, 则在表中会为此字段创建索引,默认值是False default 默认 primary_key...,blank是表单验证范畴的 6) 外键 在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理,在django.db.models中包含了可选常量: CASCADE...级联,删除主表数据时连通一起删除外键表中数据 PROTECT保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据 SET_NULL设置为NULL,仅在该字段null=True
每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。 ?...创建外键 --- 每一个班主任会对应多个学生 , 而每个学生只能对应一个班主任 ----主表 CREATE TABLE ClassCharger( id TINYINT PRIMARY...语句 --外键约束对子表的含义: 如果在父表中找不到候选键,则不允许在子表上进行insert/update --外键约束对父表的含义: 在父表上进行update/delete以更新或删除在子表中有一条或多条对...-- 应匹配行的候选键时,父表的行为取决于:在定义子表的外键时指定的 -- on update/on delete子句...带EXISTS关键字的子查询 -- EXISTS关字键字表示存在。在使用EXISTS关键字时,内层查询语句不返回查询的记录。 -- 而是返回一个真假值。
操作数据行 --> 数据的增删改查 不能创建数据库,自己动手创建数据库 使用Django的ORM详细步骤: 1....ForeignKey --> 外键 ForeignKey 字段的参数; a.to --> 设置要关联的表; b.to_field -->设置要关联的表的字段 ...from django.db import models class UserInfo(models.Model): # 自动创建一个列名为id的且为自增的整数列...一对多(出版社和书);1对多 ,外键通常设置在多的那一边; publisher = models.ForeignKey(to="Publisher") 数据库中实际 生成的是一个 publisher_id...ForeignKey(to=)),是需要添加外键的 # 而书和作者是多对多的,一本书可以有多个作者,还有一个作者也可能有多本书,即多对多的时候用(ManyToManyField(to=)) #然后ROM
字段类型 类型 说明 AutoField 自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性 BooleanField 布尔字段,值为True或False...db_index 若值为True, 则在表中会为此字段创建索引,默认值是False default 默认 primary_key 若为True,则该字段会成为模型的主键字段,默认值是False,一般作为...AutoField的选项使用 unique 如果为True, 这个字段在表中必须有唯一值,默认值是False 外键 在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理...,在django.db.models中包含了可选常量: CASCADE 级联,删除主表数据时连通一起删除外键表中数据 PROTECT 保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据...的子应用会默认为我们创建一些表, 4.4演示工具使用 4.4.1shell工具 Django的manage工具提供了shell命令,帮助我们配置好当前工程的运行环境(如连接好数据库等),以便可以直接在终端中执行测试
前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb...,如果数据库迁移,只需要更换Django的数据库引擎即可; 一、Django连接MySQL 1、创建数据库 (注意设置 数据的字符编码) 由于Django自带的orm是data_first类型的ORM,...1、无需连表查询性能低,省硬盘空间(选项不固定时用外键) 2、在modle文件里不能动态增加(选项一成不变用Django的choice) 其他字段 db_index = True 表示设置索引 unique...id的列 from django.db import models class UserInfo(models.Model): # 自动创建一个列名为....外键.关联表字段,values(外键字段__关联表字段) 多对多:外键字段.all() 反向连表操作总结: 通过value、value_list、fifter 方式反向跨表:小写表名
详见自增主键字段。 主键字段是只读的。如果你在一个已存在的对象上面更改主键的值并且保存,一个新的对象将会在原有对象之外创建出来。...中介模型有一些限制: 中介模型必须有且只有一个外键到源模型(上面例子中的Group),或者你必须使用ManyToManyField.through_fields 显式指定Django 应该使用的外键。...如果你的模型中存在超个一个的外键,并且through_fields没有指定,将会触发一个无效的错误。 对目标模型的外键有相同的限制(上面例子中的 Person)。...对于通过中介模型与自己进行多对多关联的模型,允许存在到同一个模型的两个外键,但它们将被作为多对多关联关系的两个(不同的)方面。...Changed in Django 1.7: 在Django 1.6 及之前的版本中,中介模型禁止包含多于一个的外键。
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 用于关联对象反向引用模型的名称。主要用于反向查询,即外键源模型实例通过管理器返回第一个模型的所有实例。...如果用户没有定义该选项, Django会自动将自动创建,内容是该字段属性名中的下划线转换为空格的结果。
一对一映射 创建一对一外键: 语法:OneToOneField(类名, on_delete=xxx(级联删除:在存在键的前提下的删除规则)) on_delete: models.CASCADE:级联删除...创建一对一数据 无外键的模型类,和之前相同 有外键的模型类: wife = Wife.objects.create(name=’王夫人’,author = author1(类属性名称绑实例...)) wife = Wife.objects.create(name=’王夫人’,author_id = 1(类属性字段绑值)) 一对一查询 正向查询:从外键查对象 反向查询:从对象查外键 调用反向属性查询到关联的一方...无外键的模型类,和之前相同 有外键的模型类: 类似上面 wife = Wife.objects.create(name=’王夫人’,author = author1(类属性名称绑实例)...Cookies 保存在客户端浏览器上的存储空间 特点: cookies在浏览器是以键值对的形式进行存储的,键和值都是以ASCII码的形式存储的 存储的数据带有生命周期 cookies的数据是按照域隔离的
领取专属 10元无门槛券
手把手带您无忧上云