Django LTE和GTE查询产生空的查询集

时间:2019-04-14 18:41:48

标签: django-queryset

我很困惑。我有一个Django查询,应该返回结果,但似乎没有。

我有一个数据库,其中包含具有纬度和经度数据的邮政编码模型。

class Postcode(models.Model):

name = models.CharField(max_length=50)
postcode = models.CharField(max_length=7)
latitude = models.DecimalField(max_digits=8, decimal_places=5, blank=True, null=True)
longitude = models.DecimalField(max_digits=8, decimal_places=5, blank=True, null=True)

我想在给定的邮政编码中找到100公里的邮政编码,

{'latitude': 1.445671659052796, 'longitude': 1.6673342919117797}

我发现纬度和经度范围是:

longitude_max = 1.9703812919117922
longitude_min = -1.3642872919117792
latitude_max = 52.2326886590528
latitude_min = 49.3413453409472

我这样查询数据库:

return Postcode.objects.filter(latitude__range=(latitude_min, latitude_max), longitude__range=(longitude_min, longitude_max))

但是我什么也没回来?我至少应该得到我推断范围的结果!

1 个答案:

答案 0 :(得分:0)

如果使用该坐标的那些参数进行过滤,则查询集将不包含该项目。纬度超出了提供的范围。