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