【发布时间】:2019-07-02 02:15:30
【问题描述】:
假设我有一个如下定义的表:
CREATE TABLE gtest (name varchar, geom geometry);
要插入,我可以简单地这样做:
INSERT INTO gtest
VALUES (
'Polygon',
'SRID=4326;POLYGON((0 0,1 0,1 1,0 1,0 0))'
);
我不必将 WKT 字符串包装在函数 ST_GeomFromText() 中,因为 PostGIS 具有这样做的隐式转换。 @JGH here 很好地解释了这一点
通过使用 Postgres 命令\dC,可以列出定义的强制转换,包括:
List of casts
Source type | Target type | Function | Implicit?
-------------------------+-----------------------------+--------------------+---------------
text | geometry | geometry | yes
geometry | text | text | yes
我想这样做,以便我可以简单地执行 SELECT * FROM gtest 并将几何列的结果隐式转换为 WKT。目前,它只会将它们显示为 WKB。
首先,我尝试按如下方式创建新演员:
CREATE CAST (geometry AS text) WITH FUNCTION st_astext(geometry) AS IMPLICIT;
这会返回一个错误,因为从几何到文本的转换已经存在(如表中所示)。
然后我尝试了ALTER EXTENSION postgis DROP CAST (geometry as text); 和DROP CAST (geometry as text);,然后能够创建新演员:
List of casts
Source type | Target type | Function | Implicit?
-------------------------+-----------------------------+--------------------+---------------
geometry | text | st_astext | yes
但这仍然不起作用,因为当我进行选择时,我仍然会在 WKB 中获得结果。
首先,这可能吗?我只是做错了什么吗? 其次,添加这种隐式转换会破坏任何几何函数吗?
【问题讨论】:
标签: postgresql type-conversion postgis wkt