中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

django數據關系一對多、多對多模型、自關聯的建立

發布時間:2020-09-01 13:21:19 來源:腳本之家 閱讀:155 作者:苦瓜爆炒牛肉 欄目:開發技術

一對多模型

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永泰县| 永德县| 崇州市| 仙桃市| 安溪县| 洛宁县| 蒲城县| 沧源| 阿荣旗| 镇江市| 江都市| 夏津县| 康保县| 永城市| 盈江县| 常山县| 邵东县| 从江县| 林甸县| 玉环县| 金湖县| 呼玛县| 江源县| 巴彦淖尔市| 昌平区| 柯坪县| 庄浪县| 河西区| 洛浦县| 六盘水市| 邵东县| 托克托县| 汽车| 仪陇县| 民县| 微博| 鲁甸县| 聊城市| 和政县| 原阳县| 白银市|