django 表的一对多关系创建和主从表相互查询

在modes中创建类,如下:

from django.db import models


# Create your models here.
#构建team表,作为主表
class Team(models.Model):
    #创建名字属性
    tname = models.CharField(max_length=20)
    #重写__str__方法,方便观看结果
    def __str__(self):
        return self.tname
    #定义表名
    class Meta:
        db_table = 'team'
#构建group1表,作为主表
class Group1(models.Model):
    gname = models.CharField(max_length=20)
    #多对一模型通过ForeignKey表示多对一
    # 外键设置为DO_NOTHING,从表中有记录依赖主表记录,则主表记录不允许删除
    team = models.ForeignKey(Team,on_delete=models.DO_NOTHING)

    def __str__(self):
        return self.gname

    class Meta:
        db_table = 'group1'
正向查询,主表查从表,如下:
def get_group_by_team(request):
    #得到Team中的一个对象
    team = Team.objects.get(pk=3)
    #得到team对应group1表中的数据
    print(team.group1_set.all())
    return HttpResponse(123)

总结:基本语法为:

主表对象.从表小写_set.过滤器方法
反向查询,从表查主表
def get_team_by_group(request):
    #得到Group1中的一个对象
    g1 = Group1.objects.last()
    # 一个组对应一个班级,可以通过team直接获取班级信息
    print(g1.team.tname)
    return HttpResponse("通过组获取班级信息")

总结:基本语法为:

  从表对象.主表类名小写.属性(若要获取特定属性)

跨关系查询
# 跨关系查询
def lookup1(request):
    # 从表查主表
    team = Team.objects.filter(group1__id__exact=5)

    #主表查从表
    g1 = Group1.objects.filter(team__tname='1802')

    return HttpResponse("跨关系查询")

总结:基本语法为:

从表查主表:从表类名.objects.过滤器(主表类名小写__属性__比较符='*******')

主表查从表:主表类名.objects.过滤器(从表类名小写__属性__比较符='*******')

 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值