代码还在完善中
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[t]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)drop table [dbo].[t]GO
CREATE TABLE [dbo].[t] ([id] [int] IDENTITY (1, 1) NOT NULL ,[lid] [nvarchar] (50) ,[name] [nvarchar] (50) ,[type] [int] NOT NULL ) GO
insert into t (lid,[name],[type])select '11','城站火车站',0union all select '11','葵巷建国路口',0union all select '11','菜市桥',0union all select '11','潮鸣寺巷',0union all select '11','宝善桥建国路口',0union all select '11','宝善桥',0union all select '11','市体育馆',0union all select '11','武林广场',0union all select '11','武林门',0union all select '11','武林们马塍路口',0union all select '11','八字桥',0union all select '11','浙大西溪校区',0union all select '11','庆丰村',0union all select '11','教工路口',0union all select '11','花园新村',0union all select '11','浙江工商大学',0union all select '11','电子科技大学',0union all select '11','翠苑新村',0union all select '57','大关小区',0union all select '57','通信市场',0union all select '57','德胜新村',0union all select '57','潮王路口',0union all select '57','朝晖五区',0union all select '57','朝晖三区',0union all select '57','西湖文化广场东',0union all select '57','武林广场',0union all select '57','武林小广场',0union all select '57','半道红',0union all select '57','文三路口',0union all select '57','上宁桥',0union all select '57','花园新村',0union all select '57','浙江工商大学',0union all select '57','文一路口',0union all select '57','教工路北口',0union all select '57','大关桥西',0union all select '57','上塘路口',0union all select '57','大关西六苑',0union all select '57','香积寺路口',0union all select '57','大关小区',0union all select '14','武林小广场',0union all select '14','昌化新村',0union all select '14','长寿桥',0union all select '14','延安路口',0union all select '14','中大广场',0union all select '14','众安桥',0union all select '14','浙一医院',0union all select '14','大学路北口',0union all select '14','庆春门',0union all select '14','金衙庄',0union all select '14','总管塘',0union all select '14','华东家具市场',0union all select '14','近江村',0union all select '14','汽车南站',0union all select '14','汽车南站',1union all select '14','近江村',1union all select '14','华东家具市场',1union all select '14','总管塘',1union all select '14','金衙庄',1union all select '14','庆春门',1union all select '14','大学路北口',1union all select '14','浙一医院',1union all select '14','众安桥',1union all select '14','中大广场',1union all select '14','延安路口',1union all select '14','长寿桥',1union all select '14','昌化新村',1union all select '14','武林小广场',1union all select 'K105','火车东站',0union all select 'K105','汽车东站',0union all select 'K105','严家弄',0union all select 'K105','景芳五区',0union all select 'K105','景御路口',0union all select 'K105','庆春东路',0union all select 'K105','采荷新村',0union all select 'K105','观音塘小区',0union all select 'K105','总管塘',0union all select 'K105','章家桥',0union all select 'K105','浙二医院',0union all select 'K105','官巷口',0union all select 'K105','湖滨',0union all select 'K105','胜利剧院',0union all select 'K105','孩儿巷',0union all select 'K105','延安新村',0union all select 'K105','武林小广场',0union all select 'K105','杭州大厦',0union all select 'K105','中北桥',0union all select 'K105','施家桥',0union all select 'K105','建国北路文晖路口',0union all select 'K105','文晖大桥东',0union all select 'K105','机神村',0union all select 'K105','天城路口',0union all select 'K105','新塘路口',0union all select 'K105','火车东站',0union all select '39','闸口',0union all select '39','水澄桥',0union all select '39','海月桥',0union all select '39','美政桥',0union all select '39','复兴路北口',0union all select '39','三廊庙',0union all select '39','木材新村',0union all select '39','二凉亭',0union all select '39','望江门外',0union all select '39','汽车南站',0union all select '39','近江村',0union all select '39','华东家具市场',0union all select '39','总管塘',0union all select '39','城站火车站',0union all select 'K101','城站火车站',0union all select 'K101','总管塘',0union all select 'K101','观音塘小区',0union all select 'K101','采荷新村',0union all select 'K101','红菱新村',0union all select 'K101','凤起东路口',0union all select 'K101','双菱路北口',0union all select 'K101','市红会医院',0union all select 'K101','建国路口',0union all select 'K101','新华路口',0union all select 'K101','中北路口',0union all select 'K101','延安路口',0union all select 'K101','浙大湖滨校区',0union all select 'K101','昌化新村',0union all select 'K101','市府大楼',0union all select 'K101','武林门马塍路口',0union all select 'K101','八字桥',0union all select 'K101','浙大西溪校区',0union all select 'K101','庆丰村',0union all select 'K101','玉古路天目山路口',0union all select 'K101','西湖体育馆',0union all select '21/K21','城站火车站',0union all select '21/K21','章家桥',0union all select '21/K21','新城隧道东口',0union all select '21/K21','解放路秋涛路口',0union all select '21/K21','采荷新村',0union all select '21/K21','红菱新村',0union all select '21/K21','双菱路北口',0union all select '21/K21','市红会医院',0union all select '21/K21','建国路口',0union all select '21/K21','新华路口',0union all select '21/K21','中北路口',0union all select '21/K21','延安路口',0union all select '21/K21','浙大湖滨校区',0union all select '21/K21','昌化新村',0union all select '21/K21','市府大楼',0union all select '21/K21','武林门马塍路口',0union all select '21/K21','八字桥',0union all select '21/K21','浙大西溪校区',0union all select '21/K21','庆丰村',0union all select '21/K21','跑马场',0union all select '21/K21','黄龙体育中心',0union all select '21/K21','浙大附中',0union all select '21/K21','求是路',0union all select '21/K21','西湖体育馆',0union all select '58/K58','大关小区',0union all select '58/K58','上塘路香积寺路口',0union all select '58/K58','大关西六苑',0union all select '58/K58','上塘路口',0union all select '58/K58','大关桥西',0union all select '58/K58','教工路北口',0union all select '58/K58','文一路口',0union all select '58/K58','浙江工商大学',0union all select '58/K58','花园新村',0union all select '58/K58','上宁桥',0union all select '58/K58','文三新村',0union all select '58/K58','八字桥',0union all select '58/K58','武林门马塍路口',0union all select '58/K58','武林小广场',0union all select '58/K58','武林广场',0union all select '58/K58','中北桥',0union all select '58/K58','朝晖一区',0union all select '58/K58','朝晖三区',0union all select '58/K58','朝晖五区',0union all select '58/K58','潮王路口',0union all select '58/K58','德胜新村',0union all select '58/K58','通信市场',0union all select '58/K58','大关小区',0union all select 'K101','西湖体育馆',1union all select 'K101','玉古路天目山路口',1union all select 'K101','庆丰村',1union all select 'K101','浙大西溪校区',1union all select 'K101','八字桥',1union all select 'K101','武林门马塍路口',1union all select 'K101','市府大楼',1union all select 'K101','昌化新村',1union all select 'K101','浙大湖滨校区',1union all select 'K101','延安路口',1union all select 'K101','中北路口',1union all select 'K101','新华路口',1union all select 'K101','建国路口',1union all select 'K101','市红会医院',1union all select 'K101','双菱路北口',1union all select 'K101','凤起东路口',1union all select 'K101','红菱新村',1union all select 'K101','采荷新村',1union all select 'K101','观音塘小区',1union all select 'K101','总管塘',1union all select 'K101','城站火车站',1
/****** Object:; Stored Procedure dbo.Search;Script Date: 2005-9-8 10:28:35 ******/if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[Search]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)drop procedure [dbo].[Search]GO
SET QUOTED_IDENTIFIER OFF GOSET ANSI_NULLS ON GO
/****** Object:; Stored Procedure dbo.Search;Script Date: 2005-9-8 10:28:35 ******/CREATE proc Search@name1 nvarchar(50),@name2 nvarchar(50)as
--中转站create table #tmp(tmp_id int identity(1,1),tmp_name NVARCHAR(50))
--站点队列create table #tmp1(tmp1_id int identity(1,1),tmp1_name NVARCHAR(50))
--查找结果create table #result(r_id int,r_lid nvarchar(50),r_name nvarchar(50),r_type int)
--直达insert into #resultselect c.*; from t a,t b,t c where a.lid=b.lid and a.[type]=b.[type] and a.id<b.id and a.[name] = @name1 and b.[name] = @name2and c.id>=a.id and c.id<=b.id order by c.id
if @@rowcount>0 beginselect * from #resultendelse begin--换车DECLARE @CurrenName NVARCHAR(50)SET @CurrenName = @name1change: /* --车次入栈 insert into #tmp (tmp_lid) select distinct lid from t where [name] = @CurrenName DECLARE @CurrenBus NVARCHAR(50) SELECT TOP 1 @CurrenBus = tmp_lid FROM #tmp */ INSERT INTO #tmp1 (tmp1_name) SELECT DISTINCT b.[name] FROM t a,t b WHERE a.[name] = @CurrenName AND b.lid = a.lid AND b.[name] <> @CurrenName
INSERT INTO #tmp (tmp_name) select d.[tmp1_name]; from t a,t b,t c, #tmp1 d where a.lid=b.lid and a.[type]=b.[type] and a.id<b.id and a.[name] = d.[tmp1_name] and b.[name] = @name2 and c.id>=a.id and c.id<=b.id
IF @@rowcount>0 BEGIN select distinct c.*; from t a,t b,t c,#tmp d where a.lid=b.lid and a.[type]=b.[type] and a.id<b.id and a.[name] = @name1 and b.[name] = d.tmp_name and c.id>=a.id and c.id<=b.id order by c.id select distinct c.*; from t a,t b,t c,#tmp d where a.lid=b.lid and a.[type]=b.[type] and a.id<b.id and a.[name] = d.tmp_name and b.[name] = @name2 and c.id>=a.id and c.id<=b.id order by c.id END --SELECT * FROM #tmpend
drop table #resultdrop table #tmp1drop table #tmpGO
SET QUOTED_IDENTIFIER OFF GOSET ANSI_NULLS ON GO
exec search '文一路口','总管塘'
http://blog.csdn.net/iuhxq/archive/2005/09/08/475037.aspx