Sql Server 创建父子路径

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所属者问题,加班想了想还是解决了!
有时候并不需要直接解决问题!
轻松秒杀~!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值