【发布时间】:2012-07-05 07:57:45
【问题描述】:
我有一个带有 PointField 位置坐标的模型。我有一个 MySQL 函数,它计算称为 dist 的两点之间的距离。我使用额外()“选择”来计算查询集中每个返回对象的距离。我还使用 extra() "where" 来过滤特定范围内的那些对象。像这样
query = queryset.extra(
select={
"distance":"dist(geomfromtext('%s'),geomfromtext('%s'))"%(loc1, loc2)
},
where=["1 having `distance` <= %s"%(km)]
) #simplified example
这对于获取和读取结果很有效,但当我尝试计算结果集时,我得到了 'distance' 不是字段的错误。在进一步探索之后,似乎 count 忽略了 extra 中的“select”,而只使用了“where”。完整的 SQL 查询如下所示:
SELECT (dist(geomfromtext('POINT (-4.6858300000000003 36.5154300000000021)'),geomfromtext('POINT (-4.8858300000000003 36.5154300000000021)'))) AS `distance`, `testmodel`.`id`, `testmodel`.`name`, `testmodel`.`email`, (...) FROM `testmodel` WHERE 1 having `distance` <= 50.0
count 查询要短得多,并且没有 dist 选择部分:
SELECT COUNT( `testmodel`.`id`) FROM `testmodel` WHERE 1 having `distance` <= 50.0
从逻辑上讲,MySQL 会出错,因为“距离”未定义。有没有办法告诉 Django 它必须为计数包含额外的选择?
感谢您的任何想法!
【问题讨论】:
-
你需要坚持使用mysql吗?还是可以使用其他 RDBMS?
标签: mysql django django-queryset