除了ForeignKey, ManyToManyField 和 OneToOneField之外,每个类型的字段都有一个可选的第一位置参数-详细的名字。...如果没有给出详细的名称,Django将自动使用字段的属性名来代替他。替代过程中会转换下划线为空格。...原来verbose_name字段就是为ForeignKey, ManyToManyField 和 OneToOneField这三种关系准备的啊!...20、SlugField 只能包含字母,数字,下划线和连字符的字符串,通常被用于URLs表示。可选参数max_length=50,prepopulate_from用于指示在admin表单中的可选值。...21、SmallIntegerField 小整数字段,类似于IntegerField,取值范围依赖于数据库特性,[-32768 ,32767]的取值范围对Django所支持的数据库都是安全的。
models.DateTimeField(null=True) date=models.DateField() 3、数字字段 (max_digits=30,decimal_places=10)总长度30...1、无需连表查询性能低,省硬盘空间(选项不固定时用外键) 2、在modle文件里不能动态增加(选项一成不变用Django的choice) 其他字段 db_index = True 表示设置索引 unique...、反向连表操作的认定无非是Foreign_Key字段在哪张表决定的, Foreign_Key字段在哪张表就可以哪张表使用Foreign_Key字段连表,反之没有Foreign_Key字段就使用与其关联的...小写表名; 1对多:对象.外键.关联表字段,values(外键字段__关联表字段) 多对多:外键字段.all() 反向连表操作总结: 通过value、value_list、fifter 方式反向跨表...('Boy')字段(杂交类型) ManyToManyField()字段创建第3张关系表,可以使用字段跨表查询,但无法直接操作第3张表, 自建第3表关系表可以直接操作,但无法通过字段 查询,我们可以把他们结合起来使用
Django 系列博客(十三) 前言 本篇博客介绍 Django 中的常用字段和参数。 ORM 字段 AutoField int 自增列,必须填入参数 primary_key=True。...PositiveIntegerRelDbTypeMixin, IntegerField) - 正整数 0 ~ 2147483647 BigIntegerField(IntegerField): - 长整型...Admin以及ModelForm中提供验证 URL SlugField(CharField) - 字符串类型,Django Admin以及ModelForm中提供验证支持 字母、数字、下划线、连接符...(减号) CommaSeparatedIntegerField(CharField) - 字符串类型,格式必须为逗号分割的数字 UUIDField(Field) - 字符串类型,Django Admin...through 在使用 ManyToManyField 字段时,Django 将自动生成一张表来管理多对多的关联关系。
author = models.ManyToManyField(to='Author') # django orm会自动帮我们创建书籍和作者的第三张关系表 # author这个字段是一个虚拟字段能在表中展示出来...则是我们为有名分组命的名,并且int会将匹配成功的结果转换成整型后按照格式(year=整型值)传给函数year_archive #用一个int转换器可以替代多处正则表达式 path('articles...slug,匹配字母、数字以及横杠、下划线组成的字符串。 uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。...def to_python(self, value): return int(value) def to_url(self, value): return value # 匹配的regex是两个数字...,返回的结果也必须是两个数字 在urls.py中,使用 register_converter 将其注册到URL配置中: from django.urls import path,register_converter
PositiveIntegerRelDbTypeMixin, IntegerField) - 正整数 0 ~ 2147483647 BigIntegerField(IntegerField): - 长整型...(有符号的) -9223372036854775808 ~ 9223372036854775807 自定义无符号整数字段 class UnsignedIntegerField...、数字、下划线、连接符(减号) CommaSeparatedIntegerField(CharField) - 字符串类型,格式必须为逗号分割的数字 UUIDField...一对一其实就是 一对多 + 唯一索引 # 2.当两个类之间有继承关系时,默认会创建一个一对一字段...=None, # 自定义第三张表时,使用字段用于指定关系表中那些字段做多对多关系表 from django.db
---- TextField 文本类型,可以储存大段的字符串,如博客内容等 ---- DateField 日期字段,日期格式 YYYY-MM-DD,相当于Python中的datetime.date...---- OneToOneField 一对一字段。通常一对一字段用来扩展已有字段。 ---- ManyToManyField 用于表示多对多的关联关系。...、数字、下划线、连接符(减号) CommaSeparatedIntegerField(CharField) - 字符串类型,格式必须为逗号分割的数字 UUIDField...ManyToManyField参数 to 设置要关联的表 ---- related_name 同ForeignKey字段。...---- through 在使用ManyToManyField字段时,Django将自动生成一张表来管理多对多的关联关系。
多表查询是模型层的重要功能之一, Django提供了一套基于关联字段独特的解决方案....ManyToManyField.through_fields 上文示例中Membership 有两个外键指向Person (person 和inviter),这使得关联关系含混不清并让Django 不知道使用哪一个...ManyToManyField 字段的模型的外键名称(本例中为group),field2 为指向目标模型的外键的名称(本例中为person)....ManyToManyField.db_table 默认情况下,关联表的名称使用多对多字段的名称和包含这张表的模型的名称以及Hash值生成,如:memberShip_person_3c1f5 若要想要手动指定表的名称...flight.reserve.remove(user) flight.save() 参考资料: django文档-模型字段-关联字段 django文档 - 执行查询 - 关联的对象 django文档 -
migrate --> 把更改翻译成SQL语句,去数据库执行 Django ORM常用字段: 1....ManyToManyField --> 多对多关联 5. DateField -->日期字段,日期格式 YYYY-MM-DD 6....PositiveIntegerRelDbTypeMixin, IntegerField) - 正整数 0 ~ 2147483647 BigIntegerField(IntegerField): - 长整型...、数字、下划线、连接符(减号) CommaSeparatedIntegerField(CharField) - 字符串类型,格式必须为逗号分割的数字 UUIDField...books = models.ManyToManyField(to="Book") 在数据库中: 是通过第三张表建立的关系(默认第三张表名 为字段_另一个多对多的字段) # 书 class
Django 提供了很多字段类型,比如 URL/Email/IP/ 但是 mysql 数据没有这些类型,这类型存储到数据库上本质是字符串数据类型,主要目的是为了封装底层 SQL 语句。...② 时间字段 models.DateTimeField(null=True) date = models.DateField() ③ 数字字段 # 总长度最大30位,小数位10位 (max_digits...=30, decimal_places=10) # 数字 # 整型 num = models.IntegerField() # 浮点型 floats = models.FloatField() # 精确浮点...'), (3, '普通用户') } # 枚举类型 lover = models.IntegerField(choices=choice) ⑤ 其它字段 # 设置索引 db_index = True...unique_together = ( ('email', 'name'), ) # 联合索引 index_together = ( ('telephone', 'email'), ) # 多对多操作 ManyToManyField
Model 在Django中model是你数据的单一、明确的信息来源。它包含了你存储的数据的重要字段和行为。...、数字、下划线、连接符(减号) CommaSeparatedIntegerField(CharField) - 字符串类型,格式必须为逗号分割的数字 UUIDField...一对一其实就是 一对多 + 唯一索引 # 2.当两个类之间有继承关系时,默认会创建一个一对一字段...def prefetch_related(self, *lookups) 性能相关:多表连表操作时速度会慢,使用其执行多次SQL查询在Python代码中实现连表操作。...对于多对多字段(ManyToManyField)和一对多字段,可以使用prefetch_related()来进行优化。
Django支持MySQL5.5及更高版本。 Django ORM 常用字段和参数 常用字段 AutoField int自增列,必须填入参数 primary_key=True。...PositiveIntegerRelDbTypeMixin, IntegerField) - 正整数 0 ~ 2147483647 BigIntegerField(IntegerField): - 长整型...、数字、下划线、连接符(减号) CommaSeparatedIntegerField(CharField) - 字符串类型,格式必须为逗号分割的数字 UUIDField...ManyToManyField 用于表示多对多的关联关系。在数据库中通过第三张表来建立关联关系。 字段参数 to 设置要关联的表 related_name 同ForeignKey字段。...through 在使用ManyToManyField字段时,Django将自动生成一张表来管理多对多的关联关系。
through 在使用ManyToManyField字段时,Django将自动生成一张表来管理多对多的关联关系。...要做跨关系查询,就使用两个下划线来链接模型(model)间关联字段的名称,直到最终链接到你想要的model 为止。...('age')) #是按照values里面的两个字段进行分组,两个字段同时相同才算是一组,看下面的sql语句''' SELECT `app01_dep`....如果我们要对两个字段的值做比较,那该怎么做呢?我们在book表里面加上两个字段:评论数:commentNum,收藏数:KeepNum Django 提供 F() 来做这样的比较。...F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。
字段类型 字段类型指使用Django ORM创建数据库时支持的数据字段类型。...常用字段 (1) AutoField 自增的整型字段,必填参数primary_key=True,则成为数据库的主键,无该字段时,django会自动创建主键id字段。...有两个必需的参数:max_digits数字允许的最大位数,此数字必须大于或等于decimal_places。decimal_places表示与数字一起存储的小数位数。...如: from django.db import models class Car(models.Model): manufacturer = models.ForeignKey('Manufacturer...(23) ManyToManyField 多对多关系表,需要一个位置参数:与模型相关的类,工作原理与ForeignKey完全相同,包括递归和惰性关系。
、数字、下划线、连接符(减号) CommaSeparatedIntegerField(CharField) - 字符串类型,格式必须为逗号分割的数字 UUIDField...ManyToManyField 用于表示多对多的关联关系。在数据库中通过第三张表来建立关联关系。...through: 在使用ManyToManyField字段时,Django将自动生成一张表来管理多对多的关联关系。...若你的表的名字是一个 SQL 保留字, 或包含 Python 变量名不允许的字符--特别是连字符 --没关系. Django 会自动在幕后替你将列名字和表名字用引号引起来。...的格式为:(permission_code, human_readable_permission_name). unique_together unique_together这个选项用于:当你需要通过两个字段保持唯一性时使用
models.DateTimeField(null=True) date=models.DateField() 3、数字字段 (max_digits=30,decimal_places=10)总长度...1、无需连表查询性能低,省硬盘空间(选项不固定时用外键) 2、在modle文件里不能动态增加(选项一成不变用Django的choice) 其他字段 db_index = True 表示设置索引 unique...一对多:models.ForeignKey(其他表) 多对多:models.ManyToManyField(其他表) 一对一:models.OneToOneField(其他表) 正向连表操作总结: 所谓正...、反向连表操作的认定无非是Foreign_Key字段在哪张表决定的, Foreign_Key字段在哪张表就可以哪张表使用Foreign_Key字段连表,反之没有Foreign_Key字段就使用与其关联的...小写表名; 1对多:对象.外键.关联表字段,values(外键字段__关联表字段) 多对多:外键字段.all() 反向连表操作总结: 通过value、value_list、fifter
Admin以及ModelForm中提供验证 URL SlugField(CharField) - 字符串类型,Django Admin以及ModelForm中提供验证支持 字母、数字、下划线、连接符(...减号) CommaSeparatedIntegerField(CharField) - 字符串类型,格式必须为逗号分割的数字 UUIDField(Field) - 字符串类型,Django Admin以及...关系字段用于保存数据表之间的关系,包括ForeignKey, ManyToManyField等。...一对一其实就是 一对多 + 唯一索引 # 2.当两个类之间有继承关系时,默认会创建一个一对一字段...,使用的连接前缀,用于替换【表名】 如: models.UserGroup.objects.filter(表名__字段名=1).values('表名__字段名') limit_choices_to
最后,别忘记在 setting.py 中将新创建的 app 激活。...我们可以设定三者的字段以及关系。 假设作者有姓名、Email 邮箱这两个数据属性。 假设出版社有出版社名称、地址这两个属性。 书籍有两四个属性:书名、出版日期、作者、出版社。...它带有两个可选参数:auto_now 和 auto_now_add。auto_now 表示当对象保存时,该字段会自动设置成当前时间。一般用于记录“修改时间” 。...当 ForeignKey 中有个字段 unique 被设置为 True 时, 就表示一对一关系。 3)ManyToManyField:属于模型间关系中的多对多关系。...在数据库中 Django 创建一个中间表来表示 ManyToManyField 关系。默认情况下,中间表的名称由两个关系表名结合而成。所以刚才我们创建数据库表的途中,会有四张表,而不是三表。
的社群,有想学习django的同学可以在公众号后台回复“django”,获取入群方式。...models.BigIntegerField 长整型 models.IPAddressField 字符串类型(ip4正则表达式) models.GenericIPAddressField 字符串类型...uuuuuu]] models.URLField 字符串,地址正则表达式 models.ImageField 图片类型 models.FilePathField 文件类型 Model 的连表结构...(ModelB,on_delete=models.CASCAED) ModelA 为”多“,ModelB 为”一“ 2.多对多:models.ManyToManyField(其他表) 例如 ModelA...中有个字段指向 ModelB bs = models.ManyToManyField(ModelB) ModelA 可以对应多个 ModelB 的值,同样 ModelB 可以对应多个 ModelA 的值
在哪个模型中设置 ManyToManyField 并不重要,在两个模型中任选一个即可 —— 不要两个模型都设置。 通常,ManyToManyField 实例应该位于可以编辑的表单中。...按照上面的方式,在Pizza 的表单中将允许用户选择不同的Toppings。 另见 完整的示例参见多对多关系模型示例。 ManyToManyField 字段还接受别的参数,在模型字段参考中有详细介绍。...但是,有时你可能需要关联数据到两个模型之间的关系上。 例如,有这样一个应用,它记录音乐家所属的音乐小组。我们可以用一个ManyToManyField 表示小组和成员之间的多对多关系。...对于这些情况,Django 允许你指定一个模型来定义多对多关系。 你可以将其他字段放在中介模型里面。源模型的ManyToManyField 字段将使用through 参数指向中介模型。...zip_code = models.ForeignKey(ZipCode) 字段命名的限制 Django 对字段的命名只有两个限制: 字段的名称不能是Python 保留的关键字,因为这将导致一个Python
学习 2 title 2 text 2 2019-7-2 django django 学习 3 title 3 text 3 2019-7-3 Python Python 学习 其中文章 ID 是一个数字...当然 django 还为我们提供了多种其它的数据类型,如日期时间类型 DateTimeField、整数类型 IntegerField 等等。...body = models.TextField() # 这两个列分别表示文章的创建时间和最后一次修改时间,存储时间的字段用 DateTimeField 类型。...提示: 在本教程中我们会教你这些类型的使用方法,但以后你开发自己的项目时,你就需要通过阅读 django 官方文档 关于字段类型的介绍[1] 来了解有哪些数据类型可以使用以及如何使用它们。...详细示例[3]•django ManyToManyField 简介[4]•django ManyToManyField 详细示例[5] References [1] 关于字段类型的介绍: https:/