SET STATISTICS IO ON;
SET STATISTICS TIME ON;
GO
IF OBJECT_ID(N'dbo.t1') IS NOT NULL
DROP TABLE dbo.t1;
GO
CREATE TABLE t1
(
id INT IDENTITY(1, 1)
PRIMARY KEY ,
a NVARCHAR(2) ,
b NVARCHAR(2)
);
--建立索引a
CREATE NONCLUSTERED INDEX [NonClusteredIndex-20190507-201219] ON [dbo].[t1]
(
[a] ASC
)
INCLUDE ( [b]) WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY];
GO
--建立索引b
CREATE NONCLUSTERED INDEX [NonClusteredIndex-20190507-201235] ON [dbo].[t1]
(
[b] ASC
)
INCLUDE ( [a]) WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY];
GO WITH cte_0 ( a, b )
AS ( SELECT 1 ,
2
UNION ALL
SELECT 1 ,
3
UNION ALL
SELECT 2 ,
4
UNION ALL
SELECT 2 ,
5
UNION ALL
SELECT 2 ,
3
UNION ALL
SELECT 3 ,
6
UNION ALL
SELECT 4 ,
9
UNION ALL
SELECT 5 ,
7
UNION ALL
SELECT 6 ,
9
UNION ALL
SELECT 7 ,
8
UNION ALL
SELECT 8 ,
10
UNION ALL
SELECT 9 ,
10
UNION ALL
SELECT 9 ,
12
UNION ALL
SELECT 10 ,
11
UNION ALL
SELECT 11 ,
12
)
INSERT INTO t1
( a ,
b
)
SELECT a ,
b
FROM cte_0
UNION ALL
SELECT b ,
a
FROM cte_0;
--加上是否循环的标记(效率较不加循环标记要高)
WITH cte_a
AS ( SELECT a ,
b
FROM dbo.t1
--UNION ALL
--SELECT b ,
-- a
--FROM dbo.t1
),
cte_b
AS ( SELECT a ,
b ,
0 AS isok ,
CAST(a + '>' + b AS NVARCHAR(MAX)) AS c_path ,
1 AS nlevel
FROM cte_a
WHERE a = ''--起点
UNION ALL
SELECT s.a ,
s.b ,
CASE WHEN s.b = '' THEN 1--如果下一层找到了终点,那么不需要继续向下找
ELSE 0
END AS isok ,
CAST(p.c_path + '>' + s.b AS NVARCHAR(MAX)) AS c_path ,
p.nlevel + 1
FROM cte_a AS s
INNER JOIN cte_b AS p ON p.b = s.a
WHERE CHARINDEX(s.b, p.c_path) = 0
AND p.isok = 0
),
cte_c
AS ( SELECT *
FROM cte_b
--WHERE b = '11'--终点
)
SELECT *
FROM cte_c
--WHERE cte_c.nlevel = ( SELECT MIN(cte_c.nlevel)
-- FROM cte_c
-- );
像个乞丐

t-sql最短路径搜索的更多相关文章

  1. 使用pgrouting进行最短路径搜索

       PgRouting是基于开源空间数据库PostGIS用于网络分析的扩展模块,最初它被称作pgDijkstra,因为它只是利用Dijkstra算法实现最短路径搜索,之后慢慢添加了其他的路径分析算法 ...

  2. Java室内最短路径搜索(支持多楼层)

    修改了上次的代码,现在支持室内的多楼层情况下的最短路径搜索,还是使用A*算法,把在GraphAdjList中VNode没有利用起来的data字段作为我们存储楼层属性的位置. 实际上是我偷懒了,正常情况 ...

  3. Python 图_系列之基于<链接表>实现无向图最短路径搜索

    图的常用存储方式有 2 种: 邻接炬阵 链接表 邻接炬阵的优点和缺点都很明显.优点是简单.易理解,对于大部分图结构而言,都是稀疏的,使用炬阵存储空间浪费就较大. 链接表的存储相比较邻接炬阵,使用起来更 ...

  4. A*算法的原理 <转>

    第一部分:A*算法简介    写这篇文章的初衷是应一个网友的要求,当然我也发现现在有关人工智能的中文站点实在太少,我在这里 抛砖引玉,希望大家都来热心的参与.     还是说正题,我先拿A*算法开刀, ...

  5. A*算法详解 BZOJ 1085骑士精神

    转载1:A*算法入门 http://www.cppblog.com/mythit/archive/2009/04/19/80492.aspx 在看下面这篇文章之前,先介绍几个理论知识,有助于理解A*算 ...

  6. 深入了解A*

    一.前言 在这里我将对A*算法的实际应用进行一定的探讨,并且举一个有关A*算法在最短路径搜索的例子.值得注意的是这里并不对A*的基本的概念作介绍,如果你还对A*算法不清楚的话,请看姊妹篇<初识A ...

  7. 【BZOJ】1085: [SCOI2005]骑士精神(A*启发式搜索)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1085 囧啊囧,看了题解后写了个程序,但是样例总过不了T+T,调试了不下于1个小时,肉眼对拍看了根本看 ...

  8. 单源最短路径——Dijkstra算法学习

    每次都以为自己理解了Dijkstra这个算法,但是过没多久又忘记了,这应该是第4.5次重温这个算法了. 这次是看的胡鹏的<地理信息系统>,看完之后突然意识到用数学公式表示算法流程是如此的好 ...

  9. PAT 1003

    1003. Emergency (25) As an emergency rescue team leader of a city, you are given a special map of yo ...

随机推荐

  1. pdf缩略图生成上传解决方案

    前言:因自己负责的项目(jetty内嵌启动的SpringMvc)中需要实现文件上传,而自己对java文件上传这一块未接触过,且对 Http 协议较模糊,故这次采用渐进的方式来学习文件上传的原理与实践. ...

  2. BZOJ1968: [Ahoi2005]COMMON 约数研究 线性筛

    按照积性函数的定义筛一下这个积性函数即可. #include <cstdio> #include <algorithm> #define N 1000004 #define s ...

  3. cookbook 11.1 在文本控制台中显示进度条

    任务: 在进行长时间操作时,向用户显示一个"进度指示条". 解决方案: #coding=utf-8 import sys class progressbar(object): de ...

  4. 利用栈实现字符串中三种括号的匹配问题c++语言实现

    编写一个算法,检查一个程序中的花括号,方括号和圆括号是否配对,若能够全部配对则返回1,否则返回0. Head.h: #ifndef HEAD_H_INCLUDED #define HEAD_H_INC ...

  5. 11.EL(表达式语言)

    一.EL概述 EL(Expression Language,表达式语言)是JSP2.0 中引入的新内容.通过EL可以简化在JSP中对对象的引用,从而规范页面代码,增加程序的可读性和可维护性. 1.EL ...

  6. .py文件打包成.exe文件

    # 使用pyinstaller模块 # pip install pyinstaller # 在命令行执行 pyinstaller -F xxx.py

  7. Lock和synchronized的区别

    总结来说,Lock和synchronized有以下几点不同: 1)Lock是一个接口,而synchronized是Java中的关键字,synchronized是内置的语言实现: 2)synchroni ...

  8. zabbix-server服务端配置文件

    [root@node7 ~]# vim /etc/zabbix/zabbix_server.conf ##日志文件 LogFile=/var/log/zabbix/zabbix_server.log ...

  9. 【Java面试宝典】正则表达式

    文章目录 正则表达式-语法 Pattern.compile方法 ● 请你谈谈Java中是如何支持正则表达式操作的? 考察点:正则表达式 参考回答: Java中的String类提供了支持正则表达式操作的 ...

  10. bootstrap-table前端实现多条件时间段查询数据

    实现思路:通过正则匹配到字段是否符合条件,时间段转换为时间戳比对. 这是大体的效果图: 页面的html代码 <div class="content-head mgb10"&g ...