感谢 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的参数,更新成功!