[英]Why does ST_MakeValid() strip SRID from already-defined geometries?
我正在尝试在一系列大部分同心等距多面体上使用 PostGIS ST_MakeValid()
function。 . .
. . . 它们是用明确的几何类型和 SRID 定义的(虽然它们可能不是完全有效,但仍然足够有效,可以在 QGIS 中呈现,如上所示):
trade=# \d tmp1
Table "public.tmp1"
Column | Type | Collation | Nullable | Default
-----------+-----------------------------+-----------+----------+---------
the_geom | geometry(MultiPolygon,4326) | | |
不幸的是,当我使用ST_MakeValid()
function 来创建新表时,它正在剥离 SRID 和几何类型:
trade=# CREATE TABLE tmp2 AS (SELECT ST_MakeValid(the_geom) AS the_geom_valid FROM tmp1);
SELECT 25
trade=# \d tmp2
Table "public.tmp2"
Column | Type | Collation | Nullable | Default
----------------+----------+-----------+----------+---------
the_geom_valid | geometry | | |
. . . 并且ST_SetSRID()
无法通过创建新表来解决它:
trade=# CREATE TABLE tmp3 AS (SELECT ST_SetSRID(the_geom_valid,4326) AS the_geom_srid FROM tmp2);
SELECT 25
trade=# \d tmp3
Table "public.tmp3"
Column | Type | Collation | Nullable | Default
---------------+----------+-----------+----------+---------
the_geom_srid | geometry | | |
. . . 或通过嵌套函数:
trade=# CREATE TABLE tmp4 AS (SELECT ST_SetSRID(ST_MakeValid(the_geom),4326) AS the_geom_all FROM tmp1);
SELECT 25
trade=# \d tmp4
Table "public.tmp4"
Column | Type | Collation | Nullable | Default
--------------+----------+-----------+----------+---------
the_geom_all | geometry | | |
. . . 甚至使用大家最喜欢的ST_MakeValid()
半替代品ST_Buffer()
:
trade=# CREATE TABLE tmp5 AS (SELECT ST_Buffer(the_geom,0) AS the_geom_buffer FROM tmp1);
SELECT 25
trade=# \d tmp5;
Table "public.tmp5"
Column | Type | Collation | Nullable | Default
-----------------+----------+-----------+----------+---------
the_geom_buffer | geometry | | |
在使用ST_MakeValid()
时,我找不到任何表明这是预期行为的文档 - 如何在不丢失几何类型和 SRID 的情况下创建有效几何?
正在保留 SRID。 例如,试试这个:
SELECT st_srid(the_geom_buffer) FROM tmp2 LIMIT 1;
你应该看到类似的东西:
┌─────────┐
│ st_srid │
├─────────┤
│ 4326 │
└─────────┘
这样做的原因是 ST_MakeValid() 可以返回多种类型中的任何一种,但无法提前知道它们会是什么。 从文档中:
在全部或部分维度崩溃的情况下,output 几何可能是较低到等维度几何的集合或较低维度的几何。
所以唯一的选择是返回一个通用几何。
但是,如果您确信这不会发生,您可以使用强制转换(或事后 ALTER 语句)强制它:
CREATE TABLE tmp2 AS
SELECT
ST_MakeValid(the_geom)::geometry(MultiPolygon, 4326) AS the_geom_valid
FROM tmp1;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.