【发布时间】:2014-07-17 14:17:37
【问题描述】:
我有一张如下表
cat_id Cat_Name Main_Cat_Id
1 veg null
2 main course 1
3 starter 1
4 Indian 2
5 mexican 2
6 tahi 3
7 chinese 3
8 nonveg null
9 main course 8
10 indian 9
11 starter 8
12 tahi 11
13 chinese 11
(Main_Cat_Id 是之前添加的所属类别的 cat_id)
此表用于产品的类别,其中 veg 类别有两个子类别 main course 和 starter,由 main_cat_id 并且这些子类别再次具有子类别 indian 和 mexican
而且这种分类取决于用户;他可以为印度人、墨西哥人添加更多子类别,这样他就可以拥有任何级别的分类
现在我必须选择任何节点的所有子类别,例如如果我选择蔬菜,我必须选择
(1)veg > (2)main course(1) > (4)indian(2)
> (5)mexican(2)
> (3)starter(1) > (6)thai(3)
> (7)chinese(3)
将字符串形成为 1,2,4,5,3,6,7
为此,我编写了一个 sql 函数
CREATE FUNCTION [dbo].[GetSubCategory_TEST]
( @MainCategory int, @Category varchar(max))
RETURNS varchar(max)
AS
BEGIN
IF EXISTS (SELECT Cat_Id FROM Category WHERE Main_Cat_Id=@MainCategory)
BEGIN
DECLARE @TEMP TABLE
(
CAT_ID INT
)
INSERT INTO @TEMP(CAT_ID) SELECT Cat_Id FROM Category WHERE Main_Cat_Id=@MainCategory
DECLARE @TEMP_CAT_ID INT
DECLARE CUR_CAT_ID CURSOR FOR SELECT CAT_ID FROM @TEMP
OPEN CUR_CAT_ID
WHILE 1 =1
BEGIN
FETCH NEXT FROM CUR_CAT_ID
INTO @TEMP_CAT_ID;
IF @@FETCH_STATUS <> 0
SET @Category=@Category+','+ CONVERT(VARCHAR(50), @TEMP_CAT_ID)
SET @Category = [dbo].[GetSubCategory](@TEMP_CAT_ID,@Category)
END
CLOSE CUR_CAT_ID
DEALLOCATE CUR_CAT_ID
END
return @Category
END
但是这个函数继续执行并且没有给出想要的输出我不明白发生了什么问题请帮助我得到这个
【问题讨论】:
-
while 1=1??它会无限的! ?
标签: sql-server sql-server-2008 sql-function