欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

django數(shù)據(jù)關(guān)系一對多、多對多模型、自關(guān)聯(lián)的建立

 更新時間:2019年07月24日 10:50:09   作者:苦瓜爆炒牛肉  
這篇文章主要介紹了django數(shù)據(jù)關(guān)系一對多、多對多模型、自關(guān)聯(lián)的建立

一對多模型

一對多的關(guān)系,例如員工跟部門。一個部門有多個員工。那么在django怎么建立這種表關(guān)系呢?

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

示例(見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表示兩位小數(shù),max_digits表示8個數(shù)字,包括小數(shù)的兩位
  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.在設(shè)置外鍵時,需要通過on_delete選項指明主表刪除數(shù)據(jù)時,對于外鍵引用表數(shù)據(jù)如何處理,在django.db.models中包含了可選常量:

關(guān)聯(lián)屬性on_delete選項的取值

  • models.CASCADE 此為默認(rèn)值,級聯(lián)刪除,會刪除關(guān)聯(lián)數(shù)據(jù)
department = models.ForeignKey('Department', on_delete=models.CASCADE)
  • models.PROTECT 只要存在關(guān)聯(lián)數(shù)據(jù)就不能刪除
department = models.ForeignKey('Department', on_delete=models.PROTECT)
  • models.SET_NULL 刪除數(shù)據(jù)后關(guān)聯(lián)字段設(shè)置為NULL,僅在該字段允許為null時可用(null=True)

2.如果關(guān)聯(lián)的字段不在該應(yīng)用文件夾的model.py中,那么要寫成這樣

department = models.ForeignKey("(應(yīng)用文件夾名).Department")

還有一個需要特別注意:

department = models.ForeignKey("Department",related_name='employee')時,通過部門查找員工的是用employee。如果不設(shè)置的話,是用默認(rèn)的employee_set(類名的小寫+_set)

一對多的查詢:

一個員工所屬的部門(查出來的是對象):

a = Employee.objects.get(id=1)
b = a.department

一個部門的全部員工(查出來的是對象):

a = Department.objects.get(id=1)
b = a.employee_set.all()

多對多模型

多對多的關(guān)系,例如學(xué)生與社團(tuán)。一個學(xué)生可以進(jìn)多個社團(tuán),一個社團(tuán)可以有多個學(xué)生。那么在django怎么建立這種表關(guān)系呢?

django建立多對多關(guān)系有兩種方法。

方法一:

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會自動為多對多關(guān)聯(lián)關(guān)系創(chuàng)建一張表,用于兩張表的聯(lián)系。

那么查詢呢?

1.一個社團(tuán)的全部成員(查出來的是對象)

c = Club.objects.get(id=1)
c.members.all()

2.一個成員的全部社團(tuán)(查出來的是對象)

s = Student.objects.filter(id=1)
s.club_set.all() # 類名的小寫+_set

方法二:(比較靈活)

自己手動建立一張表關(guān)聯(lián)聯(lián)系。

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")

那么這種方式建表怎么查詢呢?

一個學(xué)生加入的全部社團(tuán):

a = Student.objects.get(id=1)
b = a.membership_set.all() # 查出來的是對象
for i in b:
  print(i.club.name)

一個社團(tuán)的全部學(xué)生:

a = Club.objects.get(id=1)
b = a.membership_set.all() # 查出來的是對象
for i in b:
  print(i.student.name)

自關(guān)聯(lián)模型

自關(guān)聯(lián)模型,就是表中的某一列,關(guān)聯(lián)了這個表中的另外一列。最典型的自關(guān)聯(lián)模型就是地區(qū)表。省、市、縣都在一張表里面。省的pid為null,市的pid為省的id,縣的pid為市的id。

示例:

class Area(models.Model):  
    name = models.CharField(max_length=20, verbose_name='名稱')
    # 自關(guān)聯(lián)(特殊的一對多): 生成的字段名 parent_id
    parent = models.ForeignKey('self', verbose_name='上級行政區(qū)劃')
    class Meta:
      db_table = 'tb_areas'
      verbose_name = '行政區(qū)劃'

那么,怎么查詢呢?

如果知道一個市,叫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'

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • python字符串排序方法

    python字符串排序方法

    這篇文章主要介紹了python字符串排序方法,基于lambda實現(xiàn),是非常實用的技巧,需要的朋友可以參考下
    2014-08-08
  • Golang與python線程詳解及簡單實例

    Golang與python線程詳解及簡單實例

    這篇文章主要介紹了Golang與python線程詳解及簡單實例的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • django遷移文件migrations的實現(xiàn)

    django遷移文件migrations的實現(xiàn)

    這篇文章主要介紹了django遷移文件migrations的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • Windows下用py2exe將Python程序打包成exe程序的教程

    Windows下用py2exe將Python程序打包成exe程序的教程

    這篇文章主要介紹了Windows下用py2exe將Python程序打包成exe程序的教程,文中主要針對Python3.x版本進(jìn)行說明,需要的朋友可以參考下
    2015-04-04
  • Python 專題四 文件基礎(chǔ)知識

    Python 專題四 文件基礎(chǔ)知識

    本文主要講述了Python文件基礎(chǔ)知識,包括文件的打開、讀寫、關(guān)閉操作、使用循環(huán)讀寫文件及迭代器的知識。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • python 多維高斯分布數(shù)據(jù)生成方式

    python 多維高斯分布數(shù)據(jù)生成方式

    今天小編就為大家分享一篇python 多維高斯分布數(shù)據(jù)生成方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • 用Python將動態(tài)GIF圖片倒放播放的方法

    用Python將動態(tài)GIF圖片倒放播放的方法

    GIF(Graphics Interchange Format) 是一種可以用來呈現(xiàn)動畫效果的圖片格式,原理就是保存很多幀(Frame)靜態(tài)圖像,然后連續(xù)呈現(xiàn)。這篇文章主要介紹了用Python將動態(tài)GIF圖片倒放播放的方法,需要的朋友可以參考下
    2016-11-11
  • Python 基于 pygame 實現(xiàn)輪播圖動畫效果

    Python 基于 pygame 實現(xiàn)輪播圖動畫效果

    在Python中可以適應(yīng)第三方庫pygame來實現(xiàn)輪播圖動畫的效果,使用pygame前需確保其已經(jīng)安裝,本文通過實例代碼介紹Python 基于 pygame 實現(xiàn)輪播圖動畫效果,感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • Django實現(xiàn)簡單分頁功能的方法詳解

    Django實現(xiàn)簡單分頁功能的方法詳解

    這篇文章主要介紹了Django實現(xiàn)簡單分頁功能的方法,結(jié)合實例形式分析了django的第三方模塊django-pure-pagination的安裝、使用及實現(xiàn)分頁的相關(guān)操作技巧,需要的朋友可以參考下
    2017-12-12
  • Pytorch之ToPILImage()不輸出圖片問題及解決

    Pytorch之ToPILImage()不輸出圖片問題及解決

    這篇文章主要介紹了Pytorch之ToPILImage()不輸出圖片問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02

最新評論