1. 程式人生 > >django一對多、多對多模型的建立

django一對多、多對多模型的建立

# 轉載請留言聯絡

  • 一對多模型

一對多的關係,例如員工跟部門。一個部門有多個員工。那麼在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)