文章目录

  • django模型 数据库设计学习:
  • 一对多模型
  • 一对多的查询:
  • 多对多模型
  • 自关联模型

django模型 数据库设计学习:

作用:设计的好,会清晰,且易于理解,后续开发也事半功倍,易于维护

基本原则:

  • 一对一的表,两表的属性实际上完全可以合并成一个表,共用一个主键即可;

  • 一对多的表,可以设中间关联表,也可以将关联表并入“多”这头;若设独立关联表,则可引入“多”这头的主键作为其主键,也可另立主键并将“一”和“多”两表的主键作为关联表的外键;

  • 多对多的表,则必须设中间关联表,关联表设独立主键,并引入两个“多”头的表的主键作为关联表的外键。

  • 能用1对1的,就不用1对多;能用1对多的,就不用多对多,往简单化方向靠;
  • 能当属性处理的,尽量当属性,而不是当实体处理去另立新表,这样可使问题简化。

  • 把意义相近联系紧密的属性放在一张表内,而不是拆在多张表中。

三种关系解读:

  • ForeignKey: 多对一
  • ManyToManyField:多对多
  • OneToOneField: 一对一
    注 :要求第一个参数是一个模型类,需要使用name = models.CharField(max_length=20,verbose_name=‘例子’)verbose_name才能指定自述名

一对多模型

一对多的关系,例如员工跟部门。一个部门有多个员工。那么在django怎么建立这种表关系呢?

其实就是利用外键,在多的一方,字段指定外键即可。例如员工和部门,员工是多,所以在员工表直接部门即可。

示例(见19行):

1 class Department(models.Model):2     name = models.CharField(max_length=20)3     create_data = models.DateField(auto_now_add=True)4     is_delete = models.BooleanField(default=False)5 6     class Meta:7         db_table = "department"8 9
10 class Employee(models.Model):
11     name = models.CharField(max_length=20)
12     age = models.IntegerField()
13     gender = models.IntegerField(default=0)
14     # decimal_place = 2表示两位小数,max_digits表示8个数字,包括小数的两位
15     salary = models.DecimalField(max_digits=8,decimal_places=2)
16     # null=True 表示可以为空,blank=True表示django后台管理输入这个字段可以为空
17     comment = models.CharField(max_length=300,null=True,blank=True)
18     hire_data = models.DateField(auto_now_add=True)
19     department = models.ForeignKey("Department")
20
21     class Meta:
22         db_table = "employee"

拓展:

1.在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理,在django.db.models中包含了可选常量:

关联属性on_delete选项的取值

  • models.CASCADE 此为默认值,级联删除,会删除关联数据
    -department = models.ForeignKey(‘Department’, on_delete=models.CASCADE)

  • models.PROTECT 只要存在关联数据就不能删除
    department = models.ForeignKey(‘Department’, on_delete=models.PROTECT)

  • models.SET_NULL 删除数据后关联字段设置为NULL,仅在该字段允许为null时可用(null=True)
    2.如果关联的字段不在该应用文件夹的model.py中,那么要写成这样

department = models.ForeignKey("(应用文件夹名).Department")

还有一个需要特别注意:

department = models.ForeignKey("Department",related_name='employee')时,通过部门查找员工的是用employee。如果不设置的话,是用默认的employee_set(类名的小写+_set)

一对多的查询:


一个员工所属的部门(查出来的是对象):a = Employee.objects.get(id=1)b = a.department一个部门的全部员工(查出来的是对象):a = Department.objects.get(id=1)b = a.employee_set.all()

多对多模型

多对多的关系,例如学生与社团。一个学生可以进多个社团,一个社团可以有多个学生。那么在django怎么建立这种表关系呢?

django建立多对多关系有两种方法。

方法一:


1 class Student(models.Model):
2     name= models.CharField(max_length=16)
3     birthday=models.DateField()
4 class Club(models.Model):
5     name= models.CharField(max_length=16)
6     members = models.ManyToManyField("Student")

只需要在任意一方加上类似第6行的ManyToManyField就可以了。Django会自动为多对多关联关系创建一张表,用于两张表的联系。

那么查询呢?

1.一个社团的全部成员(查出来的是对象)
c = Club.objects.get(id=1)
c.members.all()
2.一个成员的全部社团(查出来的是对象)
s = Student.objects.filter(id=1)
s.club_set.all() # 类名的小写+_set

方法二:(比较灵活)

自己手动建立一张表关联联系。


class Student(models.Model):name= models.CharField(max_length=16)birthday=models.DateField()class Club(models.Model):name= models.CharField(max_length=16)class Membership(models.Model):student = models.ForeignKey("Student")club = models.ForeignKey("Club")

那么这种方式建表怎么查询呢?


一个学生加入的全部社团:a = Student.objects.get(id=1)b = a.membership_set.all()  # 查出来的是对象for i in b:print(i.club.name)一个社团的全部学生:a = Club.objects.get(id=1)b = a.membership_set.all()  # 查出来的是对象for i in b:print(i.student.name)

自关联模型

自关联模型,就是表中的某一列,关联了这个表中的另外一列。最典型的自关联模型就是地区表。省、市、县都在一张表里面。省的pid为null,市的pid为省的id,县的pid为市的id。

示例:


class Area(models.Model):    name = models.CharField(max_length=20, verbose_name='名称')# 自关联(特殊的一对多): 生成的字段名 parent_idparent = models.ForeignKey('self', verbose_name='上级行政区划')class Meta:db_table = 'tb_areas'verbose_name = '行政区划'

那么,怎么查询呢?

如果知道一个市,叫a市,想查他属于什么省。


a = Area.objects.get(id=1)
# b就是a市的省份的对象b = a.parent

如果知道一个省,叫a省,想查他有什么市。

a = Area.object.get(id=1)# b就是a省的全部市的对象b = a.area_set.all()    #类名小写+'_set'

django一对多、多对多模型、自关联的建立相关推荐

  1. Django 一对多 多对多 正/反序列化

    Django orm 一对多,多对多 正/反序列化 器 Django 框架操作数据库 用到的是 ORM 思想,什么是 ORM 呢? Object Relational Mapping 对象关系映射,说 ...

  2. Django框架(14.Django中模型类的关系,以及模型类关联查询)

    Django中模型类的关系,以及模型类关联查询 1.模型类关系 1.1 一对多关系 1.2多对多关系 1.3 一对一关系 1.4 一对多举例: 1.5 多对多举例: 1.6 一对一举例: 2.关联查询 ...

  3. 一对一、一对多、多对多模型关系的建立和增删改查要注意的问题

    一对一.一对多.多对多模型关系的建立和增删改查要注意的问题 一对一: 1.在维护关系的一方使用:models.OneToOneField(另一个一方模型类名称,on_delete=models.CAS ...

  4. Django一对一 ,一对多,多对多

    Django 数据库一对多,多对多 目录 app01/models.py app01/views.py app01/urls.py Python_Django/urls.py 目录 app01/mod ...

  5. Django学习日志三:模型层

    Django学习日志三:模型层1 日志一我们学习了Django的配置,详见: Django学习日志一Django的配置 日志二我们学习了创建第一个django项目,详见: Django学习日志二--创 ...

  6. Django数据库ORM模型使用(数据查询)!!!Django数据库如何使用ORM模型查询数据? ✧*。٩(ˊᗜˋ*)و✧*。 Django初体验

    文章目录 查询方法 查看执行的SQL语句 查询条件 精准与模糊查询 比较条件 时间条件 聚合函数 Avg:求平均值. Count:获取指定的对象的个数. Max和Min:获取指定对象的最大值和最小值. ...

  7. Django基础02 视图和模型

    2. Django的V和M 2.1 视图(views) 视图是Django程序中处理后端业务逻辑的地方. Django的视图是定义在子应用的views.py中的. Django的视图分为 函数视图 和 ...

  8. legend3---lavarel多对多模型操作实例

    legend3---lavarel多对多模型操作实例 一.总结 一句话总结: 在多对多模型中,增加关系表的数据 需要 弄一个和关系表一对多的模型关系 1.在lavarel关系模型中,课程和标签表是多对 ...

  9. think php 关联模型,ThinkPHP 关联模型使用图解

    通常我们所说的关联关系包括下面三种: ☆ 一对一关联:ONE_TO_ONE,包括HAS_ONE和BELONGS_TO ☆ 一对多关联:ONE_TO_MANY,包括HAS_MANY和BELONGS_TO ...

最新文章

  1. 细粒度语义分割:ICCV2019论文解析
  2. java selenium (九) 常见web UI 元素操作 及API使用
  3. 以主干开发作为持续交付的基础
  4. 2019\Province_C_C++_B\试题C-数列求值
  5. 概率论-3.2 边际分布与随机变量的独立性
  6. jQuery 属性和CSS
  7. .Net Core应用框架Util介绍(四)
  8. 前端学习(3164):react-hello-react之添加todoList
  9. mysql自定义函数重载_python pyMysql 自定义异常 函数重载
  10. python中括号配对检测_使用模板匹配在Python上进行对象检测!(附代码)
  11. 斯坦福DAWNBench最新训练排名!华为云ModelArts用时10分28秒获全球最快
  12. 浅谈Android进阶之路
  13. js默认点击一次_JavaScript初学者,一个小小的点击案例。
  14. 6. Python基础:输入输出语句介绍
  15. 字符串循环移位 编程之美3.1
  16. Nachos Lab2 虚拟内存
  17. 量子计算机模拟黑洞纠缠,科学家想用量子纠缠探查黑洞内部?那得先找到自旋方向相反的光子...
  18. Entrez Direct-入门
  19. 三星8核S5P6818 核心板(ARM Cortex-A53架构)
  20. Pygame实战:打扑克嘛?Python教你“经典纸牌游戏21点”玩法

热门文章

  1. 通过设计绿色数据中心寻求循环经济
  2. linux搭建宝塔重启mysql_宝塔面板安装 重启等命令linux系统重启
  3. Python:利用collections库实现统计单个字或单个字母的频率统计并进行降序输出、统计一个列表内重复元素并以字典形式输出
  4. 成功解决AttributeError: module tensorflow has no attribute placeholder
  5. 成功解决ValueError: attempted relative import beyond top-level package
  6. Matlab之DNN:基于Matlab利用神经网络模型(epochs=10000000)预测勒布朗詹姆斯的2018年总决赛(骑士VS勇士)第一场得分、篮板、助攻
  7. MAT之PSO:利用PSO实现对一元函数y = sin(10*pi*x) ./ x进行求解优化,找到最优个体适应度
  8. JAVA_OA(十四):SSM练手项目bug-JSP页面传递参数的编码问题
  9. TCP协议三步挥手与四步挥手
  10. openstack搭建之-nova配置(10)