postgreSQL插入到语句中会导致奇怪的(笛卡尔乘积)结果



我正在使用PostgreSQL 11和PostGIS 2.5.1,并试图在现有表中创建一个具有特定值的新列

示例表如下:

CREATE TABLE test (id integer, geom GEOMETRY);
INSERT INTO test (id, geom)
VALUES 
(1, ST_GeomFromEWKT('SRID=4326;POINT(-71.00 42.00)')),
(2, ST_GeomFromEWKT('SRID=4326;POINT(52.00 52.00)'));

如果我创建一个新列并执行插入语句,结果就像笛卡尔乘积

ALTER Table test
ADD wkt_text TEXT;

INSERT INTO test (wkt_text)
SELECT st_astext(a.geom)::text FROM test a, test b
WHERE a.id = b.id;

结果如下:

SELECT * FROM test;
id |                        geom                        |   wkt_text    
----+----------------------------------------------------+---------------
1 | 0101000020E61000000000000000C051C00000000000004540 | 
2 | 0101000020E61000000000000000004A400000000000004A40 | 
|                                                    | POINT(-71 42)
|                                                    | POINT(52 52)

发生这种情况的原因是什么?在具有空列的表上,插入到操作没有问题。只要有一列填充了值,结果就会如所述。

我通过以下查询得到了正确的结果,但我想了解原因。

WITH subquery AS (
SELECT id, st_astext(geom)::text AS wkt_text
FROM test 
)
UPDATE test
SET wkt_text=subquery.wkt_text
FROM subquery
WHERE test.id = subquery.id;

INSERT将新的插入到表中。未在INSERT中指定的列将被赋予NULL值(或指定的默认值(。

UPDATE更新现有行中的列。这似乎是你想要的逻辑,你有正确的陈述

最新更新