django数据关系一对多、多对多模型、自关联的建立
一对多模型
一对多的关系,例如员工跟部门。一个部门有多个员工。那么在django怎么建立这种表关系呢?
其实就是利用外键,在多的一方,字段指定外键即可。例如员工和部门,员工是多,所以在员工表直接部门即可。
示例(见19行):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | class Department(models.Model): name = models.CharField(max_length = 20 ) create_data = models.DateField(auto_now_add = True ) is_delete = models.BooleanField(default = False ) class Meta: db_table = "department" class Employee(models.Model): name = models.CharField(max_length = 20 ) age = models.IntegerField() gender = models.IntegerField(default = 0 ) # decimal_place = 2表示两位小数,max_digits表示8个数字,包括小数的两位 salary = models.DecimalField(max_digits = 8 ,decimal_places = 2 ) # null=True 表示可以为空,blank=True表示django后台管理输入这个字段可以为空 comment = models.CharField(max_length = 300 ,null = True ,blank = True ) hire_data = models.DateField(auto_now_add = True ) department = models.ForeignKey( "Department" ) class Meta: db_table = "employee" |
拓展:
1.在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理,在django.db.models中包含了可选常量:
关联属性on_delete选项的取值
- models.CASCADE 此为默认值,级联删除,会删除关联数据
- models.PROTECT 只要存在关联数据就不能删除
- models.SET_NULL 删除数据后关联字段设置为NULL,仅在该字段允许为null时可用(null=True)
2.如果关联的字段不在该应用文件夹的model.py中,那么要写成这样
还有一个需要特别注意:
department = models.ForeignKey("Department",related_name='employee')
时,通过部门查找员工的是用employee。如果不设置的话,是用默认的employee_set(类名的小写+_set)
一对多的查询:
一个员工所属的部门(查出来的是对象):
一个部门的全部员工(查出来的是对象):
多对多模型
多对多的关系,例如学生与社团。一个学生可以进多个社团,一个社团可以有多个学生。那么在django怎么建立这种表关系呢?
django建立多对多关系有两种方法。
方法一:
1 2 3 4 5 6 | class Student(models.Model): name = models.CharField(max_length = 16 ) birthday = models.DateField() class Club(models.Model): name = models.CharField(max_length = 16 ) members = models.ManyToManyField( "Student" ) |
只需要在任意一方加上类似第6行的ManyToManyField就可以了。Django会自动为多对多关联关系创建一张表,用于两张表的联系。
那么查询呢?
1.一个社团的全部成员(查出来的是对象)
2.一个成员的全部社团(查出来的是对象)
方法二:(比较灵活)
自己手动建立一张表关联联系。
1 2 3 4 5 6 7 8 9 10 | 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" ) |
那么这种方式建表怎么查询呢?
一个学生加入的全部社团:
1 2 3 4 | a = Student.objects.get( id = 1 ) b = a.membership_set. all () # 查出来的是对象 for i in b: print (i.club.name) |
一个社团的全部学生:
1 2 3 4 | 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。
示例:
1 2 3 4 5 6 7 | class Area(models.Model): name = models.CharField(max_length = 20 , verbose_name = '名称' ) # 自关联(特殊的一对多): 生成的字段名 parent_id parent = models.ForeignKey( 'self' , verbose_name = '上级行政区划' ) class Meta: db_table = 'tb_areas' verbose_name = '行政区划' |
那么,怎么查询呢?
如果知道一个市,叫a市,想查他属于什么省。
如果知道一个省,叫a省,想查他有什么市。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
微信公众号搜索 “ 脚本之家 ” ,选择关注
程序猿的那些事、送书等活动等着你
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!
相关文章
Keras构建神经网络踩坑(解决model.predict预测值全为0.0的问题)
这篇文章主要介绍了Keras构建神经网络踩坑(解决model.predict预测值全为0.0的问题),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-07-07Python matplotlib调整坐标轴位置、标签位置和标签方向以及X轴刻度标签位置
我们在用matplotlib绘制图的时候总是有各种需求,下面这篇文章主要给大家介绍了关于Python matplotlib调整坐标轴位置、标签位置和标签方向以及X轴刻度标签位置的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2023-04-04
最新评论