gpt4 book ai didi

postgresql - 在 PostGIS 中将几何隐式转换为 WKT 字符串

转载 作者:行者123 更新时间:2023-11-29 11:48:57 25 4
gpt4 key购买 nike

假设我有一个定义如下的表:

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);,然后能够创建新的 Actor :

                                     List of casts
Source type | Target type | Function | Implicit?
-------------------------+-----------------------------+--------------------+---------------
geometry | text | st_astext | yes

但这仍然没有用,因为当我进行选择时,我仍然在 WKB 中得到结果。

首先,这可能吗?我只是做错了什么吗?其次,任何几何函数都会因添加此隐式转换而中断吗?

最佳答案

当数据被转换为字符串或以文本模式发送到客户端时,类型输出函数被调用。在这种情况下不应用强制转换。

此函数是用 C 语言编写的,您必须破解 PostGIS 才能对其进行更改。此外,您还必须更改类型输入功能以接受文本格式。

我希望你在测试机器上做过那个实验,因为 ALTER EXTENSION 已经破坏了 PostGIS 扩展。

关于postgresql - 在 PostGIS 中将几何隐式转换为 WKT 字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54582220/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com