免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4583 | 回复: 1
打印 上一主题 下一主题

求一个单表多级层ID查询 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-01-24 10:33 |只看该作者 |倒序浏览

根据该图表我想查询出顶级ID,比如我输入tid=26就会查询出顶级tid为2,输入30查询出顶级tid=27,输入tid=9查询出对应tid=1,请问下怎么实现3层或3层以上的查询,没找到方法哎琢磨了好久了,请指导下小弟谢谢!

论坛徽章:
1
天秤座
日期:2014-04-27 07:42:20
2 [报告]
发表于 2014-01-24 12:42 |只看该作者
本帖最后由 A.com 于 2014-01-24 12:43 编辑

CREATE function GetId (@tid int) returns int as
begin
declare @isFind       bit = 0
declare @ParentId    int = 0

while @isFind = 0
  begin
  select @ParentId = pid from tablename where Id = @tid
    begin
    if @ParentId = 0
      set @isFind = 1
    else
      set @tid = @ParentId
    end
  end
return(@tid)
end
GO
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP