0

我有一个触发器,它需要一条线,抓取它的 ST_StartPoint 和 ST_EndPoint,然后抓取离这些端点最近的点,并将 node_id 分配给一列。这个 Fiddle显示了触发器以及一些示例数据。运行此触发器时,我在 QGIS 上收到错误消息,说明如下:

Could not commit changes to layer pipes

Errors: ERROR: 1 feature(s) not added.
  
  Provider errors:
      PostGIS error while adding features: ERROR:  Operation on mixed SRID geometries
    CONTEXT:  SQL statement "SELECT 
      j.node_id,
      i.node_id
                                     FROM ST_Dump(ST_SetSRID(NEW.geom,2346)) dump_line,
      LATERAL (SELECT s.node_id,(ST_SetSRID(s.geom,2346)) 
               FROM structures s
               ORDER BY ST_EndPoint((dump_line).geom)<->s.geom 
               LIMIT 1) j (node_id,geom_closest_downstream),
      LATERAL (SELECT s.node_id,(ST_SetSRID(s.geom,2346))
               FROM structures s
               ORDER BY ST_StartPoint((dump_line).geom)<->s.geom 
               LIMIT 1) i (node_id,geom_closest_upstream)"
    PL/pgSQL function sewers."Up_Str"() line 3 at SQL statement
   

我试图通过编辑触发器来解决这个问题,但这并没有解决问题。任何想法将不胜感激。

4

1 回答 1

1

这条线ORDER BY ST_EndPoint((dump_line).geom)<->s.geom(以及起点的类似线)很可能是有故障的线。

您可以再次声明s.geom. 请注意,这样做structures 不会使用任何空间索引,它必须在ST_SetSRID(geom,2346)

干净的方法是在structures表格的列级别设置 CRS

alter table structures alter column geom TYPE geometry(point,2346) using st_setSRID(geom,2346);

于 2021-07-20T14:01:11.203 回答