Django笔记&教程 4-3 模型(models)主键外键
Django 自学笔记兼学习教程第4章第3节——模型(models)主键外键
点击查看教程总目录
1 主键
梳理自官方文档:automatic-primary-key-fields
不设置主键的情况下,Django会自动为每个模型提供以下字段:
id = models.AutoField(primary_key=True)
这是个自增(auto-incrementing)主键
如果你在其他字段上设置了primary_key=True, 那么Django就不会自动给该模型添加上面的id主键了。
每个模型都需要一个字段primary_key=True(显式声明或自动添加)。
2 “复合主键”
与其说这里设置的是“复合主键”,不如说是唯一约束,因为
- 设置了“复合主键”,该模型仍然会生成1中的自增id,以其作为主键
- 设置的方法和设置约束的方法是一样的。
这里先给出一个“复合主键”代码例子,
学生以年级号、年级子学号为复合主键(唯一约束)
class Student(models.Model):
grade = models.CharField(max_length=4, verbose_name="年级")
number = models.CharField(max_length=6, verbose_name="年级子学号")
# other attritudes ...
class Meta:
constraints = [
# 复合主键:保证 grade和number组合的student_id唯一
models.UniqueConstraint(fields=['grade', 'number'], name='student_id'),
]
设置约束的写法如上。
这里我们只解释下这一个约束本身。(至于meta则会有空在本章(第四章)后面专门说下)
models.UniqueConstraint(fields=['grade', 'number'], name='student_id')
UniqueConstraint是一个唯一约束,其中fields和name都是必须要设置的参数
fields:字段名列表,指定哪几个字段名要满足唯一约束。name:约束名。
注意:这里的约束名只是该约束的名称而已,不是数据库的字段,不能用该约束名去搜索查找
3 外键(ForeignKey)
梳理自官方文档:automatic-primary-key-fields
在Django里,外键(ForeignKey)是一种关系字段(Relationship fields)
对于多对一关系,比如一个老师可以设置多个课程,可以直接像下面这样来写:
class Teacher(models.Model):
name = models.CharField(max_length=50, verbose_name="姓名")
# other attritudes ...
class Course(models.Model):
name = models.CharField(max_length=50, verbose_name="课程名")
# other attritudes ...
teacher = models.ForeignKey(Teacher, verbose_name="课程教师", on_delete=models.CASCADE)
ForeignKey有两个必需要设置的参数:
to:第一个参数,指定其外键是哪个模型,上面的例子中是Teacheron_delete: 当被一个ForeignKey引用的对象被删除时,Django将模拟on_delete参数指定的SQL约束对应的行为。通俗的来讲,这个参数设置的是删除外键引用的对象时的影响。
on_delete的可选项可以在django.db.models中找到,具体如下
CASCADE:联级删除,删除外键引用的对象时,也删除所有包含该外键的对象。
比如一个老师对应多个课程,删除一个老师,也删除该老师的所有课程。PROTECT: 阻止删除(通过抛出异常ProtectedError)SET_NULL: 将外键设置为nullSET_DEFAULT: 将外键设置为defaultSET()DO_NOTHING
4 其他关系
本文第三部分中的外键ForeignKey是一种多对一关系,
除了这种,Django中还实现了其他关系字段,这里罗列下并展示下其简单写法,
想了解更多可以通过点击其对应的链接去看对应的官方文档
# 一个课程可以有多个助教,一个助教可以辅导多个课程,这是一种多对多关系
assistant = models.ForeignKey(Teacher, verbose_name="助理教师")
- OneToOneField
# 比如每一个老师都有一个自己的单独办公室,是一种一对一关系
class Office(models.Model):
number = models.CharField(max_length=50, verbose_name="办公室号码")
# other attritudes ...
teacher = models.ForeignKey(Teacher, verbose_name="办公室老师")
Django笔记&教程 4-3 模型(models)主键外键的更多相关文章
- Django笔记&教程 6-3 使用模型(models)创建表单(form)
Django 自学笔记兼学习教程第6章第3节--使用模型(models)创建表单(form) 点击查看教程总目录 本文参考:Forms for models 1 - 初步介绍 很多时候,我们使用的表单 ...
- Django笔记&教程 总目录
本篇博客只有目录,正文内容在目录章节链接的博客里 除目录本身外,没有链接的章节,说明内容还没开始编辑 本项目笔记仍在不断创作中,还有些内容会根据自身所学不断更新完善 本项目主要为markdwon文档, ...
- EF中主表和附表一起提交的话,如果主附表的主键外键已经设定。
EF中主表和附表一起提交的话,如果主附表的主键外键已经设定,如果新增同时新增主表和附表的记录,那么在EF同时提交时,不需要人为的设定附表的主表的主键值,EF会自动为附表添加外键值.
- 第15课-数据库开发及ado.net-数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库
第15课-数据库开发及ado.net 数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库 1. 学习方法 2. 多涨见识 3. 比自己强的人一起,学习更强:比自己更聪明的人 ...
- 关系型数据库——主键&外键的
一.什么是主键.外键: 关系型数据库中的一条记录中有若干个属性,若其中某一个属性组(注意是组)能唯一标识一条记录,该属性组就可以成为一个主键 比如 学生表(学号,姓名,性别,班级) 其中每个学 ...
- CUBRID学习笔记 21 查看主键外键索引
命令 show create table game; game是表名 在web管理中,请在sql标签中查,不要在query中执行. show create table game; === <Re ...
- 5 Django系列之通过list_display展示多对多与外键内容在admin-web界面下
list_display展示多对多关系的内容 表结构关系 表一 class Server(models.Model): asset = models.OneToOneField('Asset') cr ...
- EF实体框架-从数据库更新模型 一部分表的外键(导航属性)无法显示
从数据库更新模型 要想让数据库表之间的外键关系 显示到实体模型的导航属性中去. 表的外键 对应另一张表的字段要是主键,唯一键显示不出来
- 一个模型中有两个外键指向同一张表时,创建迁移模型时报错:“ HINT: Add or change a related_name argument to the definition for 'AnswersModel.author' or 'AnswersModel.relay_to'.”解决方案
class AnswersModel(models.Model): author = models.ForeignKey(FrontUserModel,null=True,related_name=' ...
随机推荐
- xshell 连接virtualbox nat模式的虚拟主机的方式
因为垃圾CSDN抽风无法收藏文章 所以保存了一片文章 https://blog.csdn.net/Trista_WU/article/details/79873310?utm_medium=distr ...
- 前端规范之Git工作流规范(Husky + Comminilint + Lint-staged)
代码规范是软件开发领域经久不衰的话题,几乎所有工程师在开发过程中都会遇到或思考过这一问题.而随着前端应用的大型化和复杂化,越来越多的前端团队也开始重视代码规范.同样,前段时间,笔者所在的团队也开展了一 ...
- 无服务计算应用场景探讨及 FaaS 应用实战
作者 | 宋文龙(闻可) 阿里云全球技术服务部高级交付专家 什么是无服务计算 无服务器计算(Serverless Computing)在构建和运行应用时无需管理服务器等基础设施.它描述了一个细粒度的 ...
- Apache ShardingSphere 在京东白条场景的落地之旅
京东白条使用 Apache ShardingSphere 解决了千亿数据存储和扩容的问题,为大促活动奠定了基础. 2014 年初,"京东白条"作为业内互联网信用支付产品,数据量爆发 ...
- 【c++ Prime 学习笔记】第11章 关联容器
关联容器的元素按照关键字来保存和访问,而顺序容器的元素是按照在容器中的位置来保存和访问 关联容器支持高效的关键字查找和访问 2种关联容器: map中的元素是关键字-值对(key-value对),关键字 ...
- JAVA复习总体大纲
1 java基础. [1].变量--- 数据类型 变量名=值; 数据类型: 1.基本数据类型. byte[1字节] short[2字节] int[4字节] long[8字节] float[4字节] d ...
- rocketmq优雅停机往事
1 时间追溯到2018年12月的某一天夜晚,那天我正准备上线一个需求完就回家,刚点下发布按钮,告警就响起,我擦,难道回不了家了?看着报错量只有一两个,断定只是偶发,稳住不要慌. 把剩下的机器发完,又出 ...
- 北航OO第三单元总结
JML基础梳理及工具链 JML的全称是Java Modeling language,即Java建模语言.JML是一种行为接口规格.它为严格的程序设计提供了一套行之有效的方法.通过JML不仅可以基于规格 ...
- STM32定时器学习---基本定时器
STM32F1系列的产品,除了互联网产品外,工作8个,3种定时器,其中一种就是基本定时器.那么STM32单片机的基本定时器如何操作以及编程呢? 下面我们就来详细的了解一下 STM32F1系列的产品,除 ...
- 运用Tomcat创建第一个web项目
一.了解Web服务器软件 在部署tomcat前,先说一说web服务器软件是用来干什么的?简单来说,就是web容器,可以部署web项目,让用户通过浏览器来访问这些项目. 1.常见的javaweb服务器软 ...