首页 > 其他 > 详细

POSTGIS修复错误数据

时间:2020-12-02 20:03:59      阅读:88      评论:0      收藏:0      [点我收藏+]
SELECT * from river as R LIMIT 10;

-- 先备份垃圾到表temp1,然后删除垃圾数据
CREATE TABLE temp1 as select * from river where ST_IsValid(geom) = false;
delete from river where ST_IsValid( geom) = false;

-- 更改原有库表列为三维
ALTER TABLE temp1 
  ALTER COLUMN geom TYPE geometry(MultiPolygonZ)
    USING ST_Force3D(geom);

-- 更改原有库表列为三维
ALTER TABLE river 
  ALTER COLUMN geom TYPE geometry(MultiPolygonZ)
    USING ST_Force3D(geom);

-- 查询表里面有没有垃圾数据
select * from temp1 where ST_IsValid(geom) = false;
--修复垃圾数据 
update temp1 as R set geom =ST_MakeValid(ST_Force3D(R.geom));

-- 把弄好的数据插入到原表
insert into river select * from temp1;

 

POSTGIS修复错误数据

原文:https://www.cnblogs.com/lishanyang/p/14075069.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!