Как сделать запрос через модель Django и получить доступ к другой модели Django без отношения ManyToMany?
<views.py
def watchlist(request):
watchlists = WatchList.objects.filter(user=request.user)
for listing in watchlists.listing:
listings_needed = watchlists.listing()
watchlist_listing = watchlists.get(listing)
listings = Listings.objects.all().filter(watchlist_listing)
return render(request, "auctions/watchlist.html",{
"listings": listings
})
models.py
class Listings(models.Model):
CATEGORY = [
("Miscellaneous", "Miscellaneous"),
("Movies and Television", "Movies and Television"),
("Sports", "Sports"),
("Arts and Crafts", "Arts and Crafts"),
("Clothing", "Clothing"),
("Books", "Books"),
]
title = models.CharField(max_length=64)
description = models.CharField(max_length=500)
bid = models.DecimalField(max_digits=1000000000000, decimal_places=2)
image = models.URLField(null=True, blank=True)
category = models.CharField(max_length=64, choices=CATEGORY, default=None)
user = models.ForeignKey(User, on_delete=models.CASCADE, default="")
class WatchList(models.Model):
listing = models.ForeignKey(Listings, on_delete=models.CASCADE, default="")
user = models.ForeignKey(User, on_delete=models.CASCADE, default="")
Эта ошибка также возникает с текущим кодом:
arg, value = filter_expr
TypeError: cannot unpack non-iterable function object
Эта ошибка вызвана watchlist_listing = watchlists.get(listing)
.
Я также пробовал использовать цикл for, но это не сработало.
Вы можете получить все листинги для пользователя, где есть запись в модели WatchList, следуя отношениям назад в наборе запросов Listings - Listings.objects.filter(watchlist__user=user)
def watchlist(request):
listings = Listings.objects.filter(watchlist__user=request.user)
return render(request, "auctions/watchlist.html",{
"listings": listings
})