使用ChatGPT帮我改SQL报错: lwgeom_intersection: GEOS Error: TopologyException: Input geom 0 is invalid

今天开发Java代码中遇到SQL问题,报错如下,忽然想到了最近ChatGPT可以解决代码问题,为此通过ChatGPT尝试一下,试了之后果然不错,问题解决了

问题描述

问题如下:利用我自己的函数my_polygon_split函数的时候出的问题,错误意思是拓扑异常:输入geom 0无效:点处或附近的自相交,我想我之前用这个函数没问题,难道是数据问题?
在这里插入图片描述

解决思路

利用ChatGPT解决,直接提问:
在这里插入图片描述
通过这个答案可以看出,就是输入的问题,和我之前的思路一样,这个回答太棒了,还高速我解决方案。

解决措施

使用SELECT ST_IsValid(geom) 代码试了一下,果然,结果如下:
在这里插入图片描述
在这里插入图片描述
ST_Buffer:用于矢量对象生成缓冲区geometry对象,可用于缓冲区对象的显示,使用举例(其中bufferColumn字段是geometry类型):
update tableName set bufferColumn=ST_Buffer( ST_GeomFromText( ‘LINESTRING(50 50,150 150,150 50)’), 10, ‘endcap=round join=round’);

这是其中一种类型的缓冲区用法,其他用法参考:http://postgis.net/docs/ST_Buffer.html

  • 使用SELECT ST_IsValid(geom) ,ST_IsValid(ST_Buffer(geom, 0.01))分别看一下结果,如下:
  • 在这里插入图片描述
  • 通过这个结果可以看出,大概率就是这个问题了,所以,将SQL读取geometry格式的空间格式后,通过ST_Buffer(geom, 0.01)转换一下,结果测试以后,果然解决了之前的问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

努力改掉拖延症的小白

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值