django一对多、多对多模型、自关联的建立
文章目錄
- 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一对多、多对多模型、自关联的建立的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Django中Model继承的三种方式
- 下一篇: Git常见报错及解决方法