分隔字符串函数
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
????
???? --開始循環(huán)查找字符串逗號(hào)
???? WHILE(@StartIndex <= LEN(@Text))
???? BEGIN
???????? --查找字符串函數(shù) CHARINDEX? 第一個(gè)參數(shù)是要找的字符串
??????? --??????????????????????????? 第二個(gè)參數(shù)是在哪里查找這個(gè)字符串
??????? --??????????????????????????? 第三個(gè)參數(shù)是開始查找的位置
??????? --返回值是找到字符串的位置
?????? SELECT @FindIndex = CHARINDEX(@Sign,@Text,@StartIndex)
??????? --判斷有沒找到 沒找到返回0
?????? IF(@FindIndex =0 OR @FindIndex IS NULL)
???????? BEGIN
???????????? --如果沒有找到者表示找完了
?????????? SET @FindIndex = LEN(@Text)+1
???????? END
?????? --截取字符串函數(shù) SUBSTRING? 第一個(gè)參數(shù)是要截取的字符串
??????? --??????????????????????????? 第二個(gè)參數(shù)是開始的位置
???????? --??????????????????????????? 第三個(gè)參數(shù)是截取的長度
??????? --@FindIndex-@StartIndex 表示找的的位置-開始找的位置=要截取的長度
??????? --LTRIM 和 RTRIM 是去除字符串左邊和右邊的空格函數(shù)
??????? 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
????
???? --開始循環(huán)查找字符串逗號(hào)
???? WHILE(@StartIndex <= LEN(@Text))
???? BEGIN
???????? --查找字符串函數(shù) CHARINDEX? 第一個(gè)參數(shù)是要找的字符串
??????? --??????????????????????????? 第二個(gè)參數(shù)是在哪里查找這個(gè)字符串
??????? --??????????????????????????? 第三個(gè)參數(shù)是開始查找的位置
??????? --返回值是找到字符串的位置
?????? SELECT @FindIndex = CHARINDEX(@Sign,@Text,@StartIndex)
??????? --判斷有沒找到 沒找到返回0
?????? IF(@FindIndex =0 OR @FindIndex IS NULL)
???????? BEGIN
???????????? --如果沒有找到者表示找完了
?????????? SET @FindIndex = LEN(@Text)+1
???????? END
?????? --截取字符串函數(shù) SUBSTRING? 第一個(gè)參數(shù)是要截取的字符串
??????? --??????????????????????????? 第二個(gè)參數(shù)是開始的位置
???????? --??????????????????????????? 第三個(gè)參數(shù)是截取的長度
??????? --@FindIndex-@StartIndex 表示找的的位置-開始找的位置=要截取的長度
??????? --LTRIM 和 RTRIM 是去除字符串左邊和右邊的空格函數(shù)
??????? SET @Content = LTRIM(RTRIM(SUBSTRING(@Text,@StartIndex,@FindIndex-@StartIndex)))
?????? --初始化下次查找的位置
?????? SET @StartIndex = @FindIndex+1
??????? --把找的的值插入到要返回的Table類型中
???????? INSERT INTO @tempTable ([VALUE]) VALUES (@Content)
???? END
??? RETURN
?END
總結(jié)
- 上一篇: c++/cli之我见
- 下一篇: 每人都有两大炸弹的扎金花2012