Sql Server 创建父子路径
1、创建函数
CREATE function getChannelPath(@chnlid int)
returns nvarchar(1000)
AS
begin
declare @parent_Chnlid int,
@chnl_path nvarchar(1000),
@chnlName nvarchar(200)
set @chnl_path=''
set @chnlName=''
set @parent_Chnlid = @chnlid
while (@parent_Chnlid != 0)
begin
set @chnlName =( select CHNLDESC from WCMCHANNEL where CHANNELID = @parent_Chnlid)
set @parent_Chnlid=(select PARENTID from WCMCHANNEL where CHANNELID = @parent_Chnlid)
set @chnl_path = @chnlName+ '/' +@chnl_path
if (@parent_Chnlid =0)
return left(@chnl_path,len(@chnl_path)-1)
end
return @chnl_path
end
2、解决必须dbo问题
由于项目适配需要DM和sqlserver都需要一套sql,而sqlserver的自定义函数必须dbo开头,
所以折中办法,使用视图。
select CHANNELID,dbo.getChannelPath(CHANNELID) as channelname from WCMCHANNEL
3、数据来源
查数据则由视图产出,直接查询视图即可。
百度很久都没有找出如何解决自定义函数的dbo所属者问题,加班想了想还是解决了!
有时候并不需要直接解决问题!
轻松秒杀~!