分隔字符串函数
CREATE FUNCTION Split1(@Text NVARCHAR(4000),@Sign NVARCHAR(4000))
?RETURNS? @tempTable TABLE(id INT IDENTITY(1,1) PRIMARY KEY,[VALUE] NVARCHAR(4000))
?AS
?BEGIN
???? DECLARE @StartIndex INT??????????????? --開始查找的位置
??? DECLARE @FindIndex? INT??????????????? --找到的位置
???? DECLARE @Content??? VARCHAR(4000)??? --找到的值
??? --初始化一些變量
??? SET @StartIndex = 1 --T-SQL中字符串的查找位置是從1開始的
???? SET @FindIndex=0
????
???? --開始循環查找字符串逗號
???? WHILE(@StartIndex <= LEN(@Text))
???? BEGIN
???????? --查找字符串函數 CHARINDEX? 第一個參數是要找的字符串
??????? --??????????????????????????? 第二個參數是在哪里查找這個字符串
??????? --??????????????????????????? 第三個參數是開始查找的位置
??????? --返回值是找到字符串的位置
?????? SELECT @FindIndex = CHARINDEX(@Sign,@Text,@StartIndex)
??????? --判斷有沒找到 沒找到返回0
?????? IF(@FindIndex =0 OR @FindIndex IS NULL)
???????? BEGIN
???????????? --如果沒有找到者表示找完了
?????????? SET @FindIndex = LEN(@Text)+1
???????? END
?????? --截取字符串函數 SUBSTRING? 第一個參數是要截取的字符串
??????? --??????????????????????????? 第二個參數是開始的位置
???????? --??????????????????????????? 第三個參數是截取的長度
??????? --@FindIndex-@StartIndex 表示找的的位置-開始找的位置=要截取的長度
??????? --LTRIM 和 RTRIM 是去除字符串左邊和右邊的空格函數
??????? SET @Content = LTRIM(RTRIM(SUBSTRING(@Text,@StartIndex,@FindIndex-@StartIndex)))
?????? --初始化下次查找的位置
?????? SET @StartIndex = @FindIndex+1
??????? --把找的的值插入到要返回的Table類型中
???????? INSERT INTO @tempTable ([VALUE]) VALUES (@Content)
???? END
??? RETURN
?END
?RETURNS? @tempTable TABLE(id INT IDENTITY(1,1) PRIMARY KEY,[VALUE] NVARCHAR(4000))
?AS
?BEGIN
???? DECLARE @StartIndex INT??????????????? --開始查找的位置
??? DECLARE @FindIndex? INT??????????????? --找到的位置
???? DECLARE @Content??? VARCHAR(4000)??? --找到的值
??? --初始化一些變量
??? SET @StartIndex = 1 --T-SQL中字符串的查找位置是從1開始的
???? SET @FindIndex=0
????
???? --開始循環查找字符串逗號
???? WHILE(@StartIndex <= LEN(@Text))
???? BEGIN
???????? --查找字符串函數 CHARINDEX? 第一個參數是要找的字符串
??????? --??????????????????????????? 第二個參數是在哪里查找這個字符串
??????? --??????????????????????????? 第三個參數是開始查找的位置
??????? --返回值是找到字符串的位置
?????? SELECT @FindIndex = CHARINDEX(@Sign,@Text,@StartIndex)
??????? --判斷有沒找到 沒找到返回0
?????? IF(@FindIndex =0 OR @FindIndex IS NULL)
???????? BEGIN
???????????? --如果沒有找到者表示找完了
?????????? SET @FindIndex = LEN(@Text)+1
???????? END
?????? --截取字符串函數 SUBSTRING? 第一個參數是要截取的字符串
??????? --??????????????????????????? 第二個參數是開始的位置
???????? --??????????????????????????? 第三個參數是截取的長度
??????? --@FindIndex-@StartIndex 表示找的的位置-開始找的位置=要截取的長度
??????? --LTRIM 和 RTRIM 是去除字符串左邊和右邊的空格函數
??????? SET @Content = LTRIM(RTRIM(SUBSTRING(@Text,@StartIndex,@FindIndex-@StartIndex)))
?????? --初始化下次查找的位置
?????? SET @StartIndex = @FindIndex+1
??????? --把找的的值插入到要返回的Table類型中
???????? INSERT INTO @tempTable ([VALUE]) VALUES (@Content)
???? END
??? RETURN
?END
總結
- 上一篇: c++/cli之我见
- 下一篇: 每人都有两大炸弹的扎金花2012