我很困惑。我有一个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))
但是我什么也没回来?我至少应该得到我推断范围的结果!
答案 0 :(得分:0)
如果使用该坐标的那些参数进行过滤,则查询集将不包含该项目。纬度超出了提供的范围。