Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/65.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql Django queryset计数和额外选择_Mysql_Django_Django Queryset - Fatal编程技术网

Mysql Django queryset计数和额外选择

Mysql Django queryset计数和额外选择,mysql,django,django-queryset,Mysql,Django,Django Queryset,我有一个带有点域的模型来表示位置坐标。我有一个MySQL函数,它计算两点之间的距离,称为dist。我使用extra()“select”计算queryset中每个返回对象的距离。我还使用extra()“where”过滤特定范围内的对象。像这样 query = queryset.extra( select={ "distance":"dist(geomfromtext('%s'),geomfromtext('%s'))"%(loc1, loc2) }, whe

我有一个带有点域的模型来表示位置坐标。我有一个MySQL函数,它计算两点之间的距离,称为dist。我使用extra()“select”计算queryset中每个返回对象的距离。我还使用extra()“where”过滤特定范围内的对象。像这样

query = queryset.extra(
    select={
        "distance":"dist(geomfromtext('%s'),geomfromtext('%s'))"%(loc1, loc2)
    },
    where=["1 having `distance` <= %s"%(km)]
) #simplified example
query=queryset.extra(
挑选={
“距离”:“距离(geomfromtext(“%s”)、geomfromtext(“%s”))”%(loc1、loc2)
},
其中=[“1具有`distance`如果您不打算使用任何其他数据库系统,则可以使用

    params = {'point1':wktpoint1, 'point2':wktpoint2}
    query = """
        SELECT
            dist(%(point1)s, %(point2)s)
        FROM
            testmodel
    ;"""
    query_set = self.raw(query, params)
此外,如果您需要更多的GIS支持,您应该评估PostgreSQL+(如果您不想重新发明轮子,您不应该创建自己的dist函数)

Django通过GeoDjango提供GIS支持。这里有如下函数。您应该检查支持

为了使用GeoDjango,您需要在您的模型上添加一个字段,告诉他们使用,然后您就可以开始执行地理查询,并且您应该不会遇到
count
的问题

使用mysql,您可以使用geodjango完成类似的操作

### models.py
from django.contrib.gis.db import models
class YourModel(models.Model):
    your_geo_field=models.PolygonField()
    #your_geo_field=models.PointField()
    #your_geo_field=models.GeometryField()
    objects = models.GeoManager()

### your code
from django.contrib.gis.geos import *
from django.contrib.gis.measure import D
a_geom=fromstr('POINT(-96.876369 29.905320)', srid=4326)
distance=5
YoourModel.objects.filter(your_geo_field__distance_lt=(a_geom, D(m=distance))).count()

您可以看到更好的示例和参考

您需要坚持使用mysql吗?还是可以使用其他RDBMS?谢谢您的回答。我不能使用PostgreSQL,因为我们仅限于运行mysql的Amazon RDS。我可以使用原始sql。但是我如何使用COUNT()Puting dist()结果作为条件?我只需要计算结果,距离在一定范围内。MySQL有基本的GIS支持,您尝试过geodjango吗?您可以这样做:
YoourModel.objects.filter(您的\u geo\u字段\u距离\u lt=(a\u geom,D(m=5))。count()
此外,请尝试不要为距离选择距离函数使用别名。在原始查询中,应使用where子句中带有参数的函数(dist)进行筛选,然后在select子句中使用count(*)。
    params = {'point1':wktpoint1, 'point2':wktpoint2}
    query = """
        SELECT
            dist(%(point1)s, %(point2)s)
        FROM
            testmodel
    ;"""
    query_set = self.raw(query, params)
### models.py
from django.contrib.gis.db import models
class YourModel(models.Model):
    your_geo_field=models.PolygonField()
    #your_geo_field=models.PointField()
    #your_geo_field=models.GeometryField()
    objects = models.GeoManager()

### your code
from django.contrib.gis.geos import *
from django.contrib.gis.measure import D
a_geom=fromstr('POINT(-96.876369 29.905320)', srid=4326)
distance=5
YoourModel.objects.filter(your_geo_field__distance_lt=(a_geom, D(m=distance))).count()