_ | 覦覈襦 | 豕蠏手 | 殊螳 | 譯殊碁
FrontPage › 豕蟆暑谿剰鍵

讌 讌 蟲襦螳 豕蟆暑襯 谿場覲伎.
碁螳 郁屋 蠏殊 蟇磯Μ.


--drop table #edge
create table #edge(
    from_point nvarchar(20)
,   to_point nvarchar(20)
,   distance int
)
go

insert into #edge values
    (N'讌', N'覩語', 5)
,   (N'讌', N'朱貅', 10)
,   (N'讌', N'危', 9)
,   (N'覩語', N'讌', 5)
,   (N'覩語', N'朱貅', 3)
,   (N'覩語', N'', 11)
,   (N'朱貅', N'讌', 10)
,   (N'朱貅', N'覩語', 3)
,   (N'朱貅', N'ろ', 3)
,   (N'朱貅', N'', 10)
,   (N'朱貅', N'危', 7)
,   (N'危', N'讌', 9)
,   (N'危', N'朱貅', 7)
,   (N'危', N'', 7)
,   (N'危', N'蟲', 12)
,   (N'ろ', N'朱貅', 3)
,   (N'ろ', N'', 4)
,   (N'', N'ろ', 4)
,   (N'', N'朱貅', 10)
,   (N'', N'覩語', 11)
,   (N'', N'危', 7)
,   (N'', N'蟲', 2)
,   (N'蟲', N'', 2)
,   (N'蟲', N'危', 12)
go

豕蟆暑谿剰鍵
--讌 蟲襦 螳 豕蟆暑谿剰鍵
declare
    @start_point nvarchar(20)
,   @end_point nvarchar(20)

set @start_point = N'讌'
set @end_point = N'蟲'

;with cte
as
(
    select
        from_point
    ,   to_point
    ,   distance
    ,   distance distance_sum
    ,   1 step
    ,   convert(nvarchar(4000), from_point) path
    from #edge
    where from_point = @start_point
    union all
    select
        a.from_point
    ,   a.to_point
    ,   a.distance
    ,   a.distance + b.distance_sum
    ,   b.step + 1 step
    ,   convert(nvarchar(4000), b.path + '->' + a.from_point)
    from #edge a
        inner join cte b
            on a.from_point = b.to_point
            and b.path not like '%' + b.to_point + '%'
    where 1=1
    and a.from_point <> @end_point
)
select 
    path + '->' + to_point path
,   distance_sum 
,   step
from cte
where to_point = @end_point
order by distance_sum
option (maxrecursion 0);

result.png

'讌->覩語->朱貅->ろ->->蟲'螳 豕蟆暑.
蠍 蠍郁鍵..
企: : るジ讓曙 襦螻豺 企Ν 譯殊語. 襦螻豺
EditText : Print : Mobile : FindPage : DeletePage : LikePages : Powered by MoniWiki : Last modified 2018-04-13 23:12:53

語 蟠 豈螻 螳. 企Μ 企 蠏瑚 襷蟲 蟆 覯襴讌襷 覈 企 伎 暑. 語 覯襷 曙 る 蟆 蠍 覓語企. ( )