Django filter не может найти правильное решение

мои модели:

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 %}

можете мне помочь, где я ошибся

В заказе есть товары многих магазинов, я хочу отфильтровать заказ только по товарам текущего магазина

Вы можете использовать prefetch_related с Prefetch() объектами для фильтрации по связанным объектам (плюс это делает его более эффективным, решая проблему 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 %}

обратный запрос пользователя с использованием связанного имени в поле shop в order_item

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,})

Вернуться на верх