我正在使用POSTGIS =“2.0.1 r9979”并面临以下错误:
ERROR: parse error - invalid geometry
HINT: "POINT(18.570275,7" <-- parse error at position 17 within geometry
CONTEXT: SQL function "st_dwithin" during inlining
在尝试sql时:
SELECT addressid FROM maddress
WHERE ST_DWithin(geocode, 'POINT(20.0924758 72.7341809 19.137381,72.837223)' , 100.0);
我希望选择查询中提到的点之间的地址。
我已经检查了语法,并且根据语法我已将值放入查询中。请让我知道更正。
如果您试图找到两点之间的点,您可能需要使用ST_DWithin两次,以便获得基于点1的圆和基于点2的圆的交点中的点,例如,
SELECT addressid FROM maddress
WHERE ST_DWithin(geocode, ST_MakePoint(20.0924758, 72.7341809), 100.0)
AND ST_DWithin(geocode, ST_MakePoint(19.137381, 72.837223), 100.0);
请注意,单位是SRID单位,在您的情况下似乎是4326,因此您可能希望将坐标转换为米,使用地理数据类型,因此距离将以米为单位,或将距离转换为度数 - - 有各种选择。我相信你已经看过解释这些选项的ST_DWithin docs。您可能还需要考虑use_spheroid参数。
除了上面的ST_MakePoint
之外,您还可以使用ST_GeomFromText
,其形式为“POINT(x y)”,因为您最初可以选择允许您指定SRID,例如,使用4326,您也可以将查询编写为:
SELECT addressid FROM maddress
WHERE ST_DWithin(geocode, ST_GeomFromText('POINT(20.0924758 72.7341809)',4326), 100.0)
AND ST_DWithin(geocode, ST_GeomFromText('POINT(19.137381 72.837223)', 4326), 100.0);
编辑在OP的评论之后,事实证明地理编码不是几何列。您可以通过运行来解决此问题。
ALTER TABLE maddress ADD COLUMN geom GEOMETRY (POINT, 4326);
UPDATE maddress set geom=ST_MakePoint(lng,lat);
CREATE INDEX ix_spatial_geom on maddress using gist(geom);
然后,您需要在上面的查询中使用geom而不是geocode。我假设你的积分在4326。
我使用时遇到了同样的错误:
select ST_GeomFromText('POINT(-27.75 ,114.75)', 3857)
代替:
select ST_GeomFromText('POINT(-27.75 114.75)', 3857)
您需要删除逗号分隔符。