基于pgrouting的任意两点间的最短路径查询函数

基于pgrouting的任意两点间的最短路径查询函数,第1张

概述    前面文章介绍了如何利用postgresql创建空间数据库,建立空间索引和进行路径规划。但是在真实的场景中用户进行路径规划的时候都是基于经纬度数据进行路径规划的,因为用户根本不会知道道路上节点的ID。因此文本讲述如何查询任意两点间的最短路径。     一、定义函数名及函数参数         函数名定义为: pgr_fromAtoB         参数设置分别为:             

前面文章介绍了如何利用postgresql创建空间数据库,建立空间索引和进行路径规划。但是在真实的场景中用户进行路径规划的时候都是基于经纬度数据进行路径规划的,因为用户根本不会知道道路上节点的ID。因此文本讲述如何查询任意两点间的最短路径。

一、定义函数名及函数参数

函数名定义为:pgr_fromAtoB

参数设置分别为:

输入为数据库表名,起点和终点的经纬度坐标

输出为:路段序号,gID号,道路名,消耗及道路集合体。

IN tbl varchar,--数据库表名
IN x1 double precision,--起点x坐标
IN y1 double precision,--起点y坐标
IN x2 double precision,--终点x坐标
IN y2 double precision,--终点y坐标
OUT seq integer,--
OUT gID integer,
OUT name text,
OUT heading double precision,
OUT cost double precision,
OUT geom geometry

二、计算距离起点和终点距离最近的道路节点,

可以使用的函数为

SELECT ID::integer FROM minIData_vertices_pgr
ORDER BY the_geom <-> ST_GeometryFromText(''POINT('
|| x1 || ' ' || y1 || ')'',900913) liMIT 1

三、然后根据检索到的节点再调用pgrouting的最短路径查询函数进行计算。

可以使用的函数为:

SELECT gID,geom,name,cost,source,target,
ST_Reverse(geom) AS flip_geom FROM ' ||
'pgr_bdAstar(''SELECT gID as ID,source::int,target::int,'
|| 'length::float AS cost,x1,y1,x2,y2 FROM '
|| quote_IDent(tbl) || ''','
|| source || ',' || target
|| ',false,false),'
|| quote_IDent(tbl) || ' WHERE ID2 = gID ORDER BY seq

四、整合上面几个子过程,得到的最终查询sql函数如下:

----DROP FUNCTION pgr_fromAtoB(varchar,double precision,--                           double precision,double precision);CREATE OR REPLACE FUNCTION pgr_fromAtoB(                IN tbl varchar,IN x1 double precision,IN y1 double precision,IN x2 double precision,IN y2 double precision,OUT seq integer,OUT gID integer,OUT name text,OUT heading double precision,OUT cost double precision,OUT geom geometry        )        RETURNS SetoF record AS$BODY$DECLARE        sql     text;        rec     record;        source	integer;        target	integer;        point	integer;        BEGIN	-- 查询距离出发点最近的道路节点	EXECUTE 'SELECT ID::integer FROM minIData_vertices_pgr 			ORDER BY the_geom <-> ST_GeometryFromText(''POINT(' 			|| x1 || ' ' || y1 || ')'',900913) liMIT 1' INTO rec;	source := rec.ID;		-- 查询距离目的地最近的道路节点	EXECUTE 'SELECT ID::integer FROM minIData_vertices_pgr 			ORDER BY the_geom <-> ST_GeometryFromText(''POINT(' 			|| x2 || ' ' || y2 || ')'',900913) liMIT 1' INTO rec;	target := rec.ID;	-- 最短路径查询         seq := 0;        sql := 'SELECT gID,ST_Reverse(geom) AS flip_geom FROM ' ||                        'pgr_bdAstar(''SELECT gID as ID,'                                        || 'length::float AS cost,y2 FROM '                                        || quote_IDent(tbl) || ''','                                        || source || ',' || target                                         || ','                                || quote_IDent(tbl) || ' WHERE ID2 = gID ORDER BY seq';	-- Remember start point        point := source;        FOR rec IN EXECUTE sql        LOOP		-- Flip geometry (if required)		IF ( point != rec.source ) THEN			rec.geom := rec.flip_geom;			point := rec.source;		ELSE			point := rec.target;		END IF;		-- Calculate heading (simplifIEd)		EXECUTE 'SELECT degrees( ST_Azimuth( 				ST_StartPoint(''' || rec.geom::text || '''),ST_EndPoint(''' || rec.geom::text || ''') ) )' 			INTO heading;		-- Return record                seq     := seq + 1;                gID     := rec.gID;                name    := rec.name;                cost    := rec.cost;                geom    := rec.geom;                RETURN NEXT;        END LOOP;        RETURN;END;$BODY$LANGUAGE 'plpgsql' VolATILE STRICT;
总结

以上是内存溢出为你收集整理的基于pgrouting的任意两点间的最短路径查询函数全部内容,希望文章能够帮你解决基于pgrouting的任意两点间的最短路径查询函数所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1175824.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存