django ORM多表之间的联系(一对多,一对一)

问题描述:

有三张表,表1跟表2是一对多的关系,表2跟表3是一对一的关系,如何将表1跟表3连接起来

解决方案

  1. 用prefetch_related连接表1跟表2,如果此时再创建新的QuerySet会打乱prefetch_related进行的SQL优化,这时候可以使用django.db.models.Prefetch来实现,Prefetch这个提前定义好QuerySet。
  2. 在Prefetch使用select_related连接表2和表3形成一个新的QuerySet对象

测试代码如下

model.py:

from django.db import models

# Create your models here.
class GoodsType(models.Model):
    """商品类型模型类"""
    name = models.CharField(max_length=20,verbose_name='种类名称')
    logo = models.CharField(max_length=20,verbose_name='标识')

class IndexTypeGoodsBanner(models.Model):
    """首页分类商品展示模型类"""
    type = models.ForeignKey('GoodsType', verbose_name='商品类型', on_delete=models.CASCADE, related_name='goodsbanner')
    sku = models.ForeignKey('GoodsSKU', verbose_name='商品SKU', on_delete=models.CASCADE)
    index = models.SmallIntegerField(default=0, verbose_name='展示顺序')

class GoodsSKU(models.Model):
    """商品SKU模型类"""
    name = models.CharField(max_length=20, verbose_name='商品名称')

view.py:

from django.shortcuts import render
from django.db.models import  Prefetch
from django.db.models.query import QuerySet
from django.db import connection
from .models import GoodsType,IndexTypeGoodsBanner , GoodsSKU
def cs1(request):
    goodstypes = GoodsType.objects.prefetch_related(Prefetch('goodsbanner', queryset=IndexTypeGoodsBanner.objects.select_related('sku').all()))
    for x in goodstypes:
        print("GoodsType.name:",x.name)
        Banner= x.goodsbanner.all()
        for y in Banner:
        	print("IndexTypeGoodsBanner.index:", y.index)
        	print("GoodsSKU.name:", y.sku.name)
        print("="*30)
    for sql in connection.queries:
        print(sql)
    return render(request,'cs.html',{"goodstypes":goodstypes})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值