SQL分隔字串的儲存過程 (轉)

amyz發表於2007-08-15
SQL分隔字串的儲存過程 (轉)[@more@]
我在做一個專案時研究了查詢多個關鍵字的技術,這是其中用到的一個技術。
“分隔字串”過程的作用就是把“jiangjs,shenxy,cheng”類的字串隔開儲存到一個表中。
 
 
CREATE PROCEDURE [分隔字串]
(
 @String NVARCHAR(1000), -- 要分隔的字串
 @SPLITCHAR NVARCHAR(10) = ',', -- 分隔字元
 @TableName NVARCHAR(50), -- 存入的表名稱
 @FieldName NVARCHAR(50) = '[ID]' -- 存入的欄位名稱
)
AS
 
-- 將字串分隔開放進表中
 
DECLARE @L INT -- 第一個分隔字元的位置
DECLARE @S INT -- 第二個分隔字元的位置
SET @L = 0
SET @S = CHARINDEX(@SPLITCHAR, @String, @L)
 
WHILE @L <= LEN(@String)
BEGIN
 DECLARE @ID NVARCHAR(50) 
 
 IF @S = 0 SET @S = LEN(@String) + 1 -- 如果到最後一個字串那麼第二個分隔字元的位置就是這個字串的長度加一
 
 SET @ID = SUBSTRING(@String, @L, @S - @L) -- 取值
 SET @L = @S + 1
 SET @S = CHARINDEX(@SPLITCHAR, @String, @L)
 
 IF LTRIM(RTRIM(@ID)) = '' CONTINUE -- 如果是空字串就跳過
 
 DECLARE @ NVARCHAR(1000)
 SET @SQL = 'INSERT INTO ' + @TableName + ' ('+ @FieldName +') VALUES(''' + @ID + ''')'
 EXEC sp_executesql @SQL
END
GO
 
----------
Not
Messenger : to:notking@.com">notking@hotmail.com
 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752019/viewspace-957524/,如需轉載,請註明出處,否則將追究法律責任。

SQL分隔字串的儲存過程 (轉)
請登入後發表評論 登入
全部評論

相關文章