的CTE你將有一個問題遞歸若再100項
消息530,級別16,狀態1,行20語句終止。語句完成前,最大遞歸100已經耗盡。
DECLARE @TExt NVARCHAR(MAX)
SET @TExt = '100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,191,192,193,194,195,196,197,198,199,200,201,202,203'
DECLARE @Delimiter VARCHAR(1000)= ',';
WITH numbers
AS (SELECT ROW_NUMBER() OVER (ORDER BY o.object_id, o2.object_id) Number
FROM sys.objects o
CROSS JOIN sys.objects o2
),
c AS (SELECT Number CHARBegin ,
ROW_NUMBER() OVER (ORDER BY number) RN
FROM numbers
WHERE SUBSTRING(@text, Number, LEN(@Delimiter)) = @Delimiter
),
res
AS (SELECT CHARBegin ,
CAST(LEFT(@text, charbegin) AS NVARCHAR(MAX)) Res ,
RN
FROM c
WHERE rn = 1
UNION ALL
SELECT c.CHARBegin ,
CAST(SUBSTRING(@text, res.CHARBegin,
c.CHARBegin - res.CHARBegin) AS NVARCHAR(MAX)) ,
c.RN
FROM c
JOIN res ON c.RN = res.RN + 1
)
SELECT *
FROM res
我關閉這個問題,因爲我問了一個新的,更接近我的真正的問題:http://stackoverflow.com/questions/5830065/how-to-query-a單個備忘錄字段獲取許多結果每行一個 – LaBracca 2011-04-29 08:59:16
無需關閉。你可以編輯你的問題 – 2011-04-29 09:07:51
是的你是對的,我真的很着急! – LaBracca 2011-04-29 09:37:04