1. 程式人生 > >django 表的一對一關係建立和主從表相互查詢

django 表的一對一關係建立和主從表相互查詢

在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(從表類名小寫__屬性__比較符='*****')