一对多模型
一对多的关系,例如员工跟部门。一个部门有多个员工。那么在django怎么建立这种表关系呢?
其实就是利用外键,在多的一方,字段指定外键即可。例如员工和部门,员工是多,所以在员工表直接部门即可。
示例(见19行):
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 此为默认值,级联删除,会删除关联数据
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建立多对多关系有两种方法。
方法一:
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.一个社团的全部成员(查出来的是对象)
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_id parent = 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'
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】
- 林俊吉.2012-将你惜命命【美华】【WAV+CUE】
- 晓雅《分享》DTS-WAV
- 黑鸭子2008-飞歌[首版][WAV+CUE]
- 黄乙玲1989-水泼落地难收回[日本天龙版][WAV+CUE]
- 周深《反深代词》[先听版][FLAC/分轨][310.97MB]
- 姜育恒1984《什么时候·串起又散落》台湾复刻版[WAV+CUE][1G]
- 那英《如今》引进版[WAV+CUE][1G]
- 蔡幸娟.1991-真的让我爱你吗【飞碟】【WAV+CUE】
- 群星.2024-好团圆电视剧原声带【TME】【FLAC分轨】