在 PostGIS 中,几何比地理(圆形地球模型)更受欢迎,因为计算更简单,因此速度更快。它还具有更多可用功能,但在很长的距离上不太准确。
将您的 CSV 长和纬度字段导入到 DECIMAL(10,6) 列。 6 位是 10 厘米精度,对于大多数用例来说应该足够了。然后将您导入的数据转换为正确的 SRID
走错路了!
/* try what seems the obvious solution */
DROP TABLE IF EXISTS public.test_geom_bad;
-- Big Ben, London
SELECT ST_SetSRID(ST_MakePoint(-0.116773, 51.510357),4326) AS geom
INTO public.test_geom_bad;
正确的方法
/* add the necessary CAST to make it work */
DROP TABLE IF EXISTS public.test_geom_correct;
SELECT ST_SetSRID(ST_MakePoint(-0.116773, 51.510357),4326)::geometry(Geometry, 4326) AS geom
INTO public.test_geom_correct;
验证 SRID 不为零!
/* now observe the incorrect SRID 0 */
SELECT * FROM public.geometry_columns
WHERE f_table_name IN ('test_geom_bad','test_geom_correct');
使用 WKT 查看器验证 long lat 参数的顺序并
SELECT ST_AsEWKT(geom) FROM public.test_geom_correct
然后索引它以获得最佳性能
CREATE INDEX idx_target_table_geom_gist
ON target_table USING gist(geom);