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(从表类名小写__属性__比较符='*****')

 

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值