Postgis:错误:解析错误 - 无效的几何

问题描述 投票:2回答:2

我正在使用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);

我希望选择查询中提到的点之间的地址。

我已经检查了语法,并且根据语法我已将值放入查询中。请让我知道更正。

postgresql postgis
2个回答
2
投票

如果您试图找到两点之间的点,您可能需要使用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。


4
投票

我使用时遇到了同样的错误:

select ST_GeomFromText('POINT(-27.75 ,114.75)', 3857)

代替:

select ST_GeomFromText('POINT(-27.75 114.75)', 3857)

您需要删除逗号分隔符。

© www.soinside.com 2019 - 2024. All rights reserved.