django 表的一對一關係建立和主從表相互查詢
阿新 • • 發佈:2018-12-17
在model中建立學生表,資訊表(一個學生對應一個資訊),如下;
from django.db import models # Create your models here. #建立學生表 class Student(models.Model): #建立名字欄位 sname = models.CharField(max_length=30) #重寫__str__方法,方便觀察資料 def __str__(self): return self.sname class Meta: #指定表名 db_table = 'student' #建立資訊表 class Archive(models.Model): #建立電話欄位 phone = models.CharField(max_length=11) #建立一對一關係,Archive為從表,Student為主表 student = models.OneToOneField(Student,on_delete=models.PROTECT) def __str__(self): return self.phone class Meta: db_table = 'archive'
正向查詢 由主表查從表
def get_archive_by_student(request): #獲取主表中的一條物件資料 student = Student.objects.get(pk=4) print(student) # 從表是類名的小寫 #直接呼叫student.archive就可以得到student對應的從表中的資料 print(student.archive) return HttpResponse("檢視學生檔案")總結:基本語法:主表物件名.從表類名小寫
# 反向查詢 由從表查主表
def get_student_by_archive(request): archive = Archive.objects.get(pk=1) # 主表名是類名小寫 print(archive.student) return HttpResponse("由檔案檢視學生")總結:與正向查詢一個意思
跨關係查詢
def loopup(request): # 根據學生查檔案 archive = Archive.objects.filter(student__id=10) #由檔案查學生 student = Student.objects.filter(archive__phone__exact='874438251') return HttpResponse(student)總結:基本語法:
主查從
從表類名.objects.filter(主表類名小寫__屬性__比較符='****')
從查主:
主表類名.objects.filter(從表類名小寫__屬性__比較符='*****')