在SQL Server中实现最短路径搜索的解决方法.docVIP

在SQL Server中实现最短路径搜索的解决方法.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
在SQL Server中实现最短路径搜索的解决方法.doc

在SQL Server中实现最短路径搜索的解决方法 本篇文章小编为大家介绍,在SQL Server中实现最短路径搜索的解决方法。需要的朋友参考下 开始 这是去年的问题了,今天在整理邮件的时候才发现这个问题,感觉顶有意思的,特记录下来。 在表RelationGraph中,有三个字段(ID,Node,RelatedNode),其中Node和RelatedNode两个字段描述两个节点的连接关系;现在要求,找出从节点p至节点j,最短路径(即经过的节点最少)。 图1. 解析: 了能够更好的描述表RelationGraph中字段Node和 RelatedNode的关系,我在这里特意使用一个图形来描述, 如图2. 图2. 在图2,可清晰的看出各个节点直接如何相连,也可以清楚的看出节点p至节点j的的几种可能路径。 从上面可以看出第2种可能路径,经过的节点最少。 为了解决开始的问题,我参考了两种方法, 第1方法是, 参考单源最短路径算法:Dijkstra(迪杰斯特拉)算法,主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止。 图3. 第2方法是, 针对第1种方法的改进,就是采用多源点方法,这里就是以节点p和节点j为中心向外层扩展,直到两圆外切点,如图4. : 图4. 实现: 在接下来,我就描述在SQL Server中,如何实现。当然我这里采用的前面说的第2种方法,以P和J为始点像中心外层层扩展。 这里提供有表RelactionGraph的create Insert数据的脚本: 复制代码 代码如下: use TestDB go if object_id(RelactionGraph) Is not null drop table RelactionGraph create table RelactionGraph(ID int identity,Item nvarchar(50),RelactionItem nvarchar(20),constraint PK_RelactionGraph primary key(ID)) go create nonclustered index IX_RelactionGraph_Item on RelactionGraph(Item) include(RelactionItem) create nonclustered index IX_RelactionGraph_RelactionItem on RelactionGraph(RelactionItem) include(Item) go insert into RelactionGraph (Item, RelactionItem ) values (a,b),(a,c),(a,d),(a,e), (b,f),(b,g),(b,h), (c,i),(c,j), (f,k),(f,l), (k,o),(k,p), (o,i),(o,l) go 编写一个存储过程up_GetPath 复制代码 代码如下: use TestDB go --Procedure: if object_id(up_GetPath) Is not null Drop proc up_GetPath go create proc up_GetPath ( @Node nvarchar(50), @RelatedNode nvarchar(50) ) As set nocount on declare @level smallint =1, --当前搜索的深度 @MaxLevel smallint=100, --最大可搜索深度 @Node_WhileFlag bit=1, --以@Node作为中心进行搜索时候,作为能否循环搜索的标记 @RelatedNode_WhileFlag bit=1 --以@RelatedNode作为中心进行搜索时候,作为能否循环搜索的标记 --如果直接找到两个Node存在直接关系就直接返回 if Exists(select 1 from RelationGraph where (Node=@Node And RelatedNode=@RelatedNode) or (Node=@RelatedNode And RelatedNode=@Node) ) or @Node=@RelatedNode begin select convert(nvarchar(2000),@Node + -- + @RelatedNode) As RelationGraphPath,convert(smallint,0) As StopCount return end --

文档评论(0)

zhangningclb + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档