【问题标题】:django filter can't find a right solutiondjango过滤器找不到正确的解决方案
【发布时间】:2021-08-22 10:18:48
【问题描述】:

我的模型:

class Order(models.Model):
    id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
    user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, related_name="order_user")
    first_name = models.CharField(_('first name'), max_length=50)
    last_name = models.CharField(_('last name'), max_length=50)
    email = models.EmailField(_('e-mail'))
    address = models.CharField(_('address'), max_length=250)
    created = models.DateTimeField(auto_now_add=True)
    updated = models.DateTimeField(auto_now=True)

class OrderItem(models.Model):
   id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
   order = models.ForeignKey(Order, related_name='items', on_delete=models.CASCADE)
   product = models.ForeignKey(Product, related_name='order_items', on_delete=models.CASCADE)
   shop = models.ForeignKey(MyShop, related_name='shop_order', on_delete=models.CASCADE)
   price = models.DecimalField(max_digits=10, decimal_places=2)
   quantity = models.PositiveIntegerField(default=1)

我的观点:

def shop_orders(request):
    order = Order.objects.filter(items__shop=request.user.user_profile_shop)
    return render(request, 'account/paneli/shop/orders/shop_orders.html', {'order': order,})

在模板中,它显示了商店的订单,但它显示了所有商店的OrderItem

{% for order in order  %}
    order.id #it ok  
    {% for item in order.items.all %}
      
        {{ item.product }}# wrong shows the OrderItem of all the shops
       
    {% endfor %}
{% endfor %}

你能帮我看看我哪里出错了

订单中有很多店铺的产品,我想只用当前店铺的产品过滤订单

【问题讨论】:

  • ManagerOrder 在做什么?
  • @WillemVanOnsem 我出了点问题,我编辑了我的问题

标签: django django-models django-views django-forms django-templates


【解决方案1】:

您可以使用prefetch_relatedPrefetch() objects 来过滤相关对象(加上这通过解决N + 1 问题使其更有效):

from django.db.models import Prefetch


def shop_orders(request):
    orders = Order.objects.prefetch_related(
        Prefetch(
            'items',
            queryset=OrderItem.objects.filter(shop=request.user.user_profile_shop).select_related('shop'),
            to_attr='items_from_specific_shop'
        )
    )
    return render(request, 'account/paneli/shop/orders/shop_orders.html', {'orders': orders,})

然后在模板中可以写:

{% for order in orders %}
    order.id
    {% for item in order.items_from_specific_shop %}      
        {{ item.product }}
    {% endfor %}
{% endfor %}

【讨论】:

  • 嗨@Abdul Aziz Barkat,我添加了这个新行,你知道一些计算 ord_total 的方法,按顺序排列所有对象的总和
  • @GuianaAnnimali 编辑(尤其是对 answers 的编辑)并非用于提出新问题。如果您有新问题,请单独提出。
【解决方案2】:

用户在order_item的shop字段中使用相关名称进行反向查询

def shop_orders(request):
    order = Order.objects.filter(items__shop=request.user.user_profile_shop)
    shop = current_shop#get a shop whose items you need
    
    order_for_shop = shop.shop_order.all()
    return render(request, 'account/paneli/shop/orders/shop_orders.html', {'order': order_for_shop,})

【讨论】:

    猜你喜欢
    • 2015-04-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-08-30
    • 2015-05-02
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多