django數(shù)據(jù)關(guān)系一對(duì)多、多對(duì)多模型、自關(guān)聯(lián)的建立
一對(duì)多模型
一對(duì)多的關(guān)系,例如員工跟部門。一個(gè)部門有多個(gè)員工。那么在django怎么建立這種表關(guān)系呢?
其實(shí)就是利用外鍵,在多的一方,字段指定外鍵即可。例如員工和部門,員工是多,所以在員工表直接部門即可。
示例(見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個(gè)數(shù)字,包括小數(shù)的兩位 salary = models.DecimalField(max_digits=8,decimal_places=2) # null=True 表示可以為空,blank=True表示django后臺(tái)管理輸入這個(gè)字段可以為空 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è)置外鍵時(shí),需要通過on_delete選項(xiàng)指明主表刪除數(shù)據(jù)時(shí),對(duì)于外鍵引用表數(shù)據(jù)如何處理,在django.db.models中包含了可選常量:
關(guān)聯(lián)屬性on_delete選項(xiàng)的取值
- models.CASCADE 此為默認(rèn)值,級(jí)聯(lián)刪除,會(huì)刪除關(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時(shí)可用(null=True)
2.如果關(guān)聯(lián)的字段不在該應(yīng)用文件夾的model.py中,那么要寫成這樣
department = models.ForeignKey("(應(yīng)用文件夾名).Department")
還有一個(gè)需要特別注意:
department = models.ForeignKey("Department",related_name='employee')
時(shí),通過部門查找員工的是用employee。如果不設(shè)置的話,是用默認(rèn)的employee_set(類名的小寫+_set)
一對(duì)多的查詢:
一個(gè)員工所屬的部門(查出來的是對(duì)象):
a = Employee.objects.get(id=1) b = a.department
一個(gè)部門的全部員工(查出來的是對(duì)象):
a = Department.objects.get(id=1) b = a.employee_set.all()
多對(duì)多模型
多對(duì)多的關(guān)系,例如學(xué)生與社團(tuán)。一個(gè)學(xué)生可以進(jìn)多個(gè)社團(tuán),一個(gè)社團(tuán)可以有多個(gè)學(xué)生。那么在django怎么建立這種表關(guān)系呢?
django建立多對(duì)多關(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會(huì)自動(dòng)為多對(duì)多關(guān)聯(lián)關(guān)系創(chuàng)建一張表,用于兩張表的聯(lián)系。
那么查詢呢?
1.一個(gè)社團(tuán)的全部成員(查出來的是對(duì)象)
c = Club.objects.get(id=1) c.members.all()
2.一個(gè)成員的全部社團(tuán)(查出來的是對(duì)象)
s = Student.objects.filter(id=1) s.club_set.all() # 類名的小寫+_set
方法二:(比較靈活)
自己手動(dòng)建立一張表關(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")
那么這種方式建表怎么查詢呢?
一個(gè)學(xué)生加入的全部社團(tuán):
a = Student.objects.get(id=1) b = a.membership_set.all() # 查出來的是對(duì)象 for i in b: print(i.club.name)
一個(gè)社團(tuán)的全部學(xué)生:
a = Club.objects.get(id=1) b = a.membership_set.all() # 查出來的是對(duì)象 for i in b: print(i.student.name)
自關(guān)聯(lián)模型
自關(guān)聯(lián)模型,就是表中的某一列,關(guān)聯(lián)了這個(gè)表中的另外一列。最典型的自關(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)(特殊的一對(duì)多): 生成的字段名 parent_id parent = models.ForeignKey('self', verbose_name='上級(jí)行政區(qū)劃') class Meta: db_table = 'tb_areas' verbose_name = '行政區(qū)劃'
那么,怎么查詢呢?
如果知道一個(gè)市,叫a市,想查他屬于什么省。
a = Area.objects.get(id=1) # b就是a市的省份的對(duì)象 b = a.parent
如果知道一個(gè)省,叫a省,想查他有什么市。
a = Area.object.get(id=1) # b就是a省的全部市的對(duì)象 b = a.area_set.all() #類名小寫+'_set'
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- django ManyToManyField多對(duì)多關(guān)系的實(shí)例詳解
- Django之多對(duì)多查詢與操作方法詳解
- Django 多對(duì)多字段的更新和插入數(shù)據(jù)實(shí)例
- Django中數(shù)據(jù)庫的數(shù)據(jù)關(guān)系:一對(duì)一,一對(duì)多,多對(duì)多
- 基于Django ORM、一對(duì)一、一對(duì)多、多對(duì)多的全面講解
- Django 標(biāo)簽篩選的實(shí)現(xiàn)代碼(一對(duì)多、多對(duì)多)
- django 多對(duì)多表的創(chuàng)建和插入代碼實(shí)現(xiàn)
- Django Xadmin多對(duì)多字段過濾實(shí)例
- Django中多對(duì)多關(guān)系三種定義方式
相關(guān)文章
django遷移文件migrations的實(shí)現(xiàn)
這篇文章主要介紹了django遷移文件migrations的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03Windows下用py2exe將Python程序打包成exe程序的教程
這篇文章主要介紹了Windows下用py2exe將Python程序打包成exe程序的教程,文中主要針對(duì)Python3.x版本進(jìn)行說明,需要的朋友可以參考下2015-04-04用Python將動(dòng)態(tài)GIF圖片倒放播放的方法
GIF(Graphics Interchange Format) 是一種可以用來呈現(xiàn)動(dòng)畫效果的圖片格式,原理就是保存很多幀(Frame)靜態(tài)圖像,然后連續(xù)呈現(xiàn)。這篇文章主要介紹了用Python將動(dòng)態(tài)GIF圖片倒放播放的方法,需要的朋友可以參考下2016-11-11Python 基于 pygame 實(shí)現(xiàn)輪播圖動(dòng)畫效果
在Python中可以適應(yīng)第三方庫pygame來實(shí)現(xiàn)輪播圖動(dòng)畫的效果,使用pygame前需確保其已經(jīng)安裝,本文通過實(shí)例代碼介紹Python 基于 pygame 實(shí)現(xiàn)輪播圖動(dòng)畫效果,感興趣的朋友跟隨小編一起看看吧2024-03-03Django實(shí)現(xiàn)簡單分頁功能的方法詳解
這篇文章主要介紹了Django實(shí)現(xiàn)簡單分頁功能的方法,結(jié)合實(shí)例形式分析了django的第三方模塊django-pure-pagination的安裝、使用及實(shí)現(xiàn)分頁的相關(guān)操作技巧,需要的朋友可以參考下2017-12-12Pytorch之ToPILImage()不輸出圖片問題及解決
這篇文章主要介紹了Pytorch之ToPILImage()不輸出圖片問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02