关于博文“PGRouting初探”的一点补充

感谢 PGRouting初探 作者的无私奉献,按照他说的使用迪杰斯特算法,很快我就实验成功了,但是后面使用AStar算法时,更新起点,终点坐标到sampledata表遇到了问题;


原来他导入shp数据时,系统默认用geometry(LineString)保存点串,我导入时总是使用geometry(MutiLineString)类型,然后执行这个sql时总是无法更新数据:

UPDATE sampledata SET x1 = ST_x(ST_PointN(geom, 1));
UPDATE sampledata SET y1 = ST_y(ST_PointN(geom, 1));
UPDATE sampledata SET x2 = ST_x(ST_PointN(geom, ST_NumPoints(geom)));
UPDATE sampledata SET y2 = ST_y(ST_PointN(geom, ST_NumPoints(geom)));

执行完了,对应的x1-y2的参数一直空。


解决方法:

#增加新列存放点串
ALTER TABLE sampledata ADD COLUMN "geom2" geometry(LineString);

#将Gomeotry中的MutiLineString合并到LineString,否则无法从中提取点坐标
UPDATE sampledata SET geom2 = ST_LineMerge(geom);


修改后,更新以上的x1-y2的参数,更新成功!




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值