[英]How to link and filter data from 3 tables in Django orm
我想過濾用戶尚未投票的帖子(啤酒)。 為此,我需要將帖子與評分表和有用戶的幫助表結合起來。 在db https://drive.google.com/file/d/1MkL4IVtviIcPo7XFptoybPthNyO4dUp_/view?usp=sharing中收集示例表格
class Beerpost(models.Model):
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, null=True, blank=True, editable=False)
title = models.CharField("Назва", max_length=160)
slug = models.SlugField(max_length=160, unique=True)
img = ProcessedImageField(upload_to='static/img/%Y/%m/%d/%H/%M/%S/', processors = [ResizeToFit(150, 385)], format='JPEG', options={'quality': 90})
type_beer = models.ForeignKey(
Type,
verbose_name="Тип пива",
on_delete=models.SET_NULL,
null=True,
blank=True, default=1)
volume = models.ForeignKey(Vol, verbose_name="Об'єм л.", on_delete=models.CASCADE, null=True, blank=True, default=3)
price_limit = models.ForeignKey(Price, on_delete=models.CASCADE, null=True, blank=True, verbose_name='Орієнтовна ціна', default=4)
country = models.ForeignKey(Country, on_delete=models.CASCADE, null=True, blank=True, verbose_name='Країна', default=3)
created = models.DateTimeField("Дата створення", auto_now_add=True)
is_active = models.BooleanField(default=True)
created = models.DateTimeField(auto_now_add=True, auto_now=False)
updated = models.DateTimeField(auto_now_add=False, auto_now=True)
ratings = GenericRelation(Rating, related_query_name='foos')
favorite = models.BooleanField(default=False, editable=False)
users_reaction_favorite = models.ManyToManyField(settings.AUTH_USER_MODEL, blank=True, related_name="users_reaction_favorite", editable=False)
我嘗試這個
all_beer = Beerpost.objects.all()
user_table = UserRating.objects.filter(user_id = pk)
join_user_table = user_table.select_related()
但是我不知道如何結合這三個查詢。 請Pleace幫我,我三天不能解決這個問題(請幫助我,我三天不能解決這個問題(或向我推薦其他解決方案。
您可以使用以下查詢:
Beerpost.objects.exclude(ratings__user=)
與user
的用戶對象,您要為其獲得Beerpost
對象,而user
不屬於ratings
。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.