首页 > 解决方案 > Django QuerySet 什么都不返回

问题描述

我有一个国家/地区列表,例如,它们都有自己的网址 www.example.com/al/。每个国家/地区都有一个城市列表,但 object_list 为空

我的观点:

class CityOverview(generic.ListView):
    template_name = 'shisha/pages/country_index.html'
    model = City

    def get_queryset(self, *args, **kwargs):
        country_id = self.kwargs.get('country_id')
        return City.objects.filter(country__name=country_id)

我的模型:

class Country(models.Model):
    COUNTRY_CHOICES = (
        ('al', 'Albania'),
        ('ad', 'Andorra'),
        #etc. etc.
    )
    name = models.CharField(max_length=255, choices=COUNTRY_CHOICES, default='nl')

    def __str__(self):
      return self.name

class City(models.Model):
    country = models.ForeignKey(Country, on_delete=models.CASCADE)
    name = models.CharField(max_length=250)

    def __str__(self):
      return self.name

我的网址:

path('<str:country_id>', views.CityOverview.as_view(), name='country'),

我的模板:

{{ object_list }}

它返回一个空的 QuerySet

<QuerySet []>

有谁知道问题是什么?

标签: djangodjango-modelsdjango-templatesdjango-views

解决方案


问题是你试图匹配country__namecountry_id. 将最后一行更改为get_queryset现在return City.objects.filter(country__id=country_id)将根据的国家 ID过滤country_id提供的内容。City


推荐阅读