Django过滤器排除外键

时间:2018-05-03 00:58:45

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

我正在编写一个新闻网站,其中有两个模型News和BestNews.News是BestNews.News的外键代表所有新闻,Best News被选为推荐新闻。

现在我已经在index.html中呈现了新闻列表和最佳新闻列表。但这两部分中的一些新闻是重复的。

我希望在最佳新闻列表中的新闻不会出现在新闻列表中,一旦我从管理员的最佳新闻中删除了新闻,已从最佳新闻中删除的新闻将出现新闻列表。

这是我的新闻模式:

class News(models.Model):
    title = models.CharField(max_length=100, verbose_name='标题') 
    content = UEditorField(verbose_name="内容", width=600, height=300, imagePath="news/ueditor/", filePath="news/ueditor/", default='')

    class Meta:
        verbose_name = "新闻"
        verbose_name_plural = verbose_name

    def __str__(self):
        return self.title

这是我的最佳新闻模式:

class Best(models.Model):
    select_news = models.ForeignKey(News, on_delete=models.CASCADE, related_name='select_news',verbose_name='要闻')  
    SELECT_REASON = (
        ('左一', '左一'),
        ('左二', '左二'),
    )
    select_reason = models.CharField(choices=SELECT_REASON, max_length=50, null=False)  

    class Meta:
        verbose_name = "精选"
        verbose_name_plural = verbose_name

    def __str__(self):
        return self.select_reason + '-' + self.select_news.title

这是我的新闻列表视图:我在一个视图中获得新闻列表和最佳新闻列表。

class NewsView(View):

    def get(self, request):
        all_news = News.objects.all().order_by('-pk')
        bestnews1 = Best.objects.filter(select_reason="左一")[0].select_news
        bestnews2 = Best.objects.filter(select_reason="左二")[0].select_news

        return render(request, 'index.html', {
            'all_news': news,
             'bestnews1':bestnews1,
             'bestnews2':bestnews1,
        })

1 个答案:

答案 0 :(得分:2)

reboot()

all_news = News.objects.all().order_by('-pk')

免费咨询:

更改

all_news = News.objects.filter(select_news__isnull=True).order_by('-pk')

bestnews1 = Best.objects.filter(select_reason="左一")[0].select_news