【发布时间】:2016-05-29 23:29:20
【问题描述】:
来自这个答案:Is there a way to loop through a table variable in TSQL without using a cursor?
我正在使用方法
WHILE EXISTS(SELECT * FROM #Temp)
问题是它输出多个表,如果可能的话我想输出为一个表。
Declare @Id int
WHILE EXISTS(SELECT * FROM #Temp)
Begin
Select Top 1 @Id = Id From #Temp
--Do some processing here
Delete #Temp Where Id = @Id
End
所以现在它会输出:
x y
-- --
1 a
x y
-- --
1 b
但我希望它输出这个:
x y
-- --
1 a
2 b
我想要实现的目标,我在一个领域有这个:
1234,1432,1235
我有一个将字段拆分为记录的过程(它适用于 sql server 2000):
DECLARE @String VARCHAR(100)
SELECT @String = str FROM field --with the 1234,1432,1235
SELECT SUBSTRING(',' + @String + ',', Number + 1,
CHARINDEX(',', ',' + @String + ',', Number + 1) - Number -1)AS str
INTO #temp
FROM master..spt_values
WHERE Type = 'P'
AND Number <= LEN(',' + @String + ',') - 1
AND SUBSTRING(',' + @String + ',', Number, 1) = ','
GO
所以现在,#temp 有:
str
---
1234
1432
1235
所以我需要遍历每条记录来查询我需要的信息。
我希望它输出如下内容:
str name age
--- ---- ---
1234 Bob 23
1432 Jay 41
1235 Tim 12
当前的 While 循环像这样输出它,这是我不想要的:
str name age
--- ---- ---
1234 Bob 23
str name age
--- ---- ---
1432 Jay 41
str name age
--- ---- ---
1235 Tim 12
最终工作结果:
SET NOCOUNT ON;
DECLARE @String VARCHAR(1000);
SELECT @String = Tnn FROM (SELECT
CO.USER_2 AS Tnn
FROM
[VMFG].[dbo].[CUSTOMER_ORDER] AS CO
LEFT JOIN DBO.Tnn_Header AS Tnn ON Tnn.TnnNumber = CO.USER_2 AND Tnn.StatusID = '5' WHERE CO.ID = 'ORDERID') AS Place --with the 1234,1432,1235
DECLARE @Id nvarchar(50),
@Discount nvarchar(50),
@Spin nvarchar(50),
@Commission_Hmm nvarchar(50),
@Commission nvarchar(50),
@TnnID nvarchar(50);
DECLARE @Output TABLE (
TnnNumber nvarchar(50),
Discount nvarchar(50),
Spin nvarchar(50),
Commission_Hmm nvarchar(50),
Commission nvarchar(50),
TnnID nvarchar(50));
DECLARE crs CURSOR STATIC LOCAL READ_ONLY FORWARD_ONLY
FOR SELECT SUBSTRING(',' + @String + ',', Number + 1,
CHARINDEX(',', ',' + @String + ',', Number + 1) - Number -1) AS [ID]
FROM master..spt_values
WHERE Type = 'P'
AND Number <= LEN(',' + @String + ',') - 1
AND SUBSTRING(',' + @String + ',', Number, 1) = ',';
OPEN crs;
FETCH NEXT
FROM crs
INTO @Id;
WHILE (@@FETCH_STATUS = 0)
BEGIN
-- do some processing..
SELECT
@Id = TH.TnnNumber,
@Discount = CASE WHEN COUNT(DISTINCT TL.DiscountCodeID) > 1 THEN 'Varies, View Tnn' ELSE CAST(MAX(DC.Value) AS VARCHAR(60)) END,
@Spin = CASE WHEN TS.SpinID > 4 THEN 'Has Specifics, View Tnn' ELSE TS.Value END,
@Commission_Hmm = CASE WHEN COUNT(DISTINCT TL.Commission_Hmm) > 1 THEN 'Varies, View Tnn' ELSE CAST(MAX( ISNULL(str(TL.Commission_Hmm,12),'Default Comm')) AS VARCHAR(60)) END,
@Commission = CASE WHEN COUNT(DISTINCT TL.Commission) > 1 THEN 'Varies, View Tnn' ELSE CAST(MAX(ISNULL(str(TL.Commission,12),'Default Comm')) AS VARCHAR(60)) END,
@TnnID = TL.TnnID
FROM DBO.Tnn_Header AS TH
LEFT JOIN DBO.Tnn_LINE AS TL ON TH.TnnID = TL.TnnID
LEFT JOIN DBO.Tnn_Spin AS TS ON TH.SpinID = TS.SpinID
LEFT JOIN DBO.Tnn_DiscountCode AS DC ON TL.DiscountCodeID = DC.DiscountCodeID
WHERE TnnNumber = @id
GROUP BY
TH.TnnNumber,
TS.SpinID,
TS.Value,
TL.TnnID
-- end do some processing..
INSERT INTO @Output (TnnNumber, Discount, Spin, Commission_Hmm, Commission, TnnID)
VALUES (@Id, @Discount, @Spin, @Commission_Hmm, @Commission, @TnnID);
FETCH NEXT
FROM crs
INTO @Id;
END;
CLOSE crs;
DEALLOCATE crs;
SELECT TnnNumber, Discount, Spin, Commission_Hmm, Commission, TnnID
FROM @Output;
【问题讨论】:
-
你的输出语句在哪里?
-
尝试在您的选择语句中的唯一字段上添加 order by
-
@inquisitive_mind 没有 INTO #temp2 它的输出就像“所以现在它放这个:”的正下方一样:
-
您必须将修改后的列数据插入另一个临时表,然后在 WHILE 之外打印出来。
标签: sql-server tsql while-loop cursor sql-server-2000