django一對多、多對多模型、自關聯的創建

# 原創,轉載請留言聯繫git

  • 一對多模型

一對多的關係,例如員工跟部門。一個部門有多個員工。那麼在django怎麼創建這種表關係呢?django

其實就是利用外鍵,在多的一方,字段指定外鍵便可。例如員工和部門,員工是多,因此在員工表直接部門便可。spa

示例(見19行):code

 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中包含了可選常量:blog

關聯屬性on_delete選項的取值ip

  • models.CASCADE 此爲默認值,級聯刪除,會刪除關聯數據ci

    department = models.ForeignKey('Department', on_delete=models.CASCADE)
  • models.PROTECT 只要存在關聯數據就不能刪除get

    department = models.ForeignKey('Department', on_delete=models.PROTECT)
  • models.SET_NULL 刪除數據後關聯字段設置爲NULL,僅在該字段容許爲null時可用(null=Trueit

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_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'

相關文章
相關標籤/搜索