SQL根據(jù)指定分隔符分解字符串實(shí)現(xiàn)步驟
更新時(shí)間:2012年11月26日 17:44:41 作者:
想要在MS SQL中根據(jù)給定的分隔符把這個(gè)字符串分解成各個(gè)元素,本文將詳細(xì)介紹此功能的實(shí)現(xiàn),需要了解的朋友可以參考下
如果有一個(gè)字符串 eg: "sun,star,moon,clouds",想要在MS SQL中根據(jù)給定的分隔符','把這個(gè)字符串分解成各個(gè)元素[sun] [star] [moon] [clouds],如何實(shí)現(xiàn)呢?為此,創(chuàng)建一個(gè)Function,代碼如下:
CREATE FUNCTION [dbo].[Split_StrByDelimiter](@String VARCHAR(8000), @Delimiter CHAR(1))
RETURNS @temptable TABLE (items VARCHAR(8000))
AS
BEGIN
DECLARE @idx INT
DECLARE @slice VARCHAR(8000)
SELECT @idx = 1
IF len(@String)<1 OR @String IS NULL RETURN
while @idx!= 0
BEGIN
SET @idx = charindex(@Delimiter,@String)
IF @idx!=0
SET @slice = LEFT(@String,@idx - 1)
ELSE
SET @slice = @String
IF(len(@slice)>0)
INSERT INTO @temptable(Items) VALUES(@slice)
SET @String = RIGHT(@String,len(@String) - @idx)
IF len(@String) = 0 break
END
RETURN
END
示例:如果輸入
SELECT * FROM dbo.Split_StrByDelimiter('sun,star,moon,clouds',',')
結(jié)果返回
sun
star
moon
clouds
在上面的代碼做變形,返回有多少個(gè)元素
CREATE FUNCTION [dbo].[GetCount_Split_StrByDelimiter](@String VARCHAR(8000), @Delimiter CHAR(1))
RETURNS INT
AS
BEGIN
DECLARE @temptable TABLE (items VARCHAR(8000))
DECLARE @SplitCount INT
DECLARE @idx INT
DECLARE @slice VARCHAR(8000)
SELECT @idx = 1
IF len(@String)<1 OR @String IS NULL RETURN 0
while @idx!= 0
BEGIN
SET @idx = charindex(@Delimiter,@String)
IF @idx!=0
SET @slice = LEFT(@String,@idx - 1)
ELSE
SET @slice = @String
IF(len(@slice)>0)
INSERT INTO @temptable(Items) VALUES(@slice)
SET @String = RIGHT(@String,len(@String) - @idx)
IF len(@String) = 0 break
END
SET @SplitCount=(SELECT COUNT(*) FROM @temptable)
RETURN @SplitCount
END
示例
SELECT dbo.GetCount_Split_StrByDelimiter('sun,star,moon,clouds',',')
結(jié)果返回
4
復(fù)制代碼 代碼如下:
CREATE FUNCTION [dbo].[Split_StrByDelimiter](@String VARCHAR(8000), @Delimiter CHAR(1))
RETURNS @temptable TABLE (items VARCHAR(8000))
AS
BEGIN
DECLARE @idx INT
DECLARE @slice VARCHAR(8000)
SELECT @idx = 1
IF len(@String)<1 OR @String IS NULL RETURN
while @idx!= 0
BEGIN
SET @idx = charindex(@Delimiter,@String)
IF @idx!=0
SET @slice = LEFT(@String,@idx - 1)
ELSE
SET @slice = @String
IF(len(@slice)>0)
INSERT INTO @temptable(Items) VALUES(@slice)
SET @String = RIGHT(@String,len(@String) - @idx)
IF len(@String) = 0 break
END
RETURN
END
示例:如果輸入
SELECT * FROM dbo.Split_StrByDelimiter('sun,star,moon,clouds',',')
結(jié)果返回
sun
star
moon
clouds
在上面的代碼做變形,返回有多少個(gè)元素
復(fù)制代碼 代碼如下:
CREATE FUNCTION [dbo].[GetCount_Split_StrByDelimiter](@String VARCHAR(8000), @Delimiter CHAR(1))
RETURNS INT
AS
BEGIN
DECLARE @temptable TABLE (items VARCHAR(8000))
DECLARE @SplitCount INT
DECLARE @idx INT
DECLARE @slice VARCHAR(8000)
SELECT @idx = 1
IF len(@String)<1 OR @String IS NULL RETURN 0
while @idx!= 0
BEGIN
SET @idx = charindex(@Delimiter,@String)
IF @idx!=0
SET @slice = LEFT(@String,@idx - 1)
ELSE
SET @slice = @String
IF(len(@slice)>0)
INSERT INTO @temptable(Items) VALUES(@slice)
SET @String = RIGHT(@String,len(@String) - @idx)
IF len(@String) = 0 break
END
SET @SplitCount=(SELECT COUNT(*) FROM @temptable)
RETURN @SplitCount
END
示例
SELECT dbo.GetCount_Split_StrByDelimiter('sun,star,moon,clouds',',')
結(jié)果返回
4
相關(guān)文章
我也有微信朋友圈了 Android實(shí)現(xiàn)
最近寫了一個(gè)簡(jiǎn)單的朋友圈程序,包含了朋友圈的列表實(shí)現(xiàn),視頻的錄制、預(yù)覽與上傳,圖片可選擇拍照或者從相冊(cè)選取,從相冊(cè)選取可以一次選擇多張照片,并且限制照片的張數(shù),想擁有真正屬于自己的朋友圈嗎?快來圍觀2016-05-05sql server代理中作業(yè)執(zhí)行SSIS包失敗的解決辦法
這篇文章主要介紹了sql server代理中作業(yè)執(zhí)行SSIS包失敗的解決辦法,sql2005如何用dtexec運(yùn)行ssis(DTS)包?本文講的非常詳細(xì),小伙伴們一起學(xué)習(xí)吧2015-09-09積分獲取和消費(fèi)的存儲(chǔ)過程學(xué)習(xí)示例
這篇文章主要介紹了積分獲取和消費(fèi)的存儲(chǔ)過程學(xué)習(xí)示例,這個(gè)只是學(xué)習(xí)一下存儲(chǔ)過程的使用方法,需要的朋友可以參考下2014-03-03SQL學(xué)習(xí)筆記五去重,給新加字段賦值的方法
SQL學(xué)習(xí)筆記五去重,給新加字段賦值的方法,需要的朋友可以參考下。2011-08-08SQL Server自動(dòng)更新統(tǒng)計(jì)信息的基本算法
最初接觸SQL Server的時(shí)候認(rèn)為SQLServer數(shù)據(jù)更改的同時(shí)就會(huì)相應(yīng)的更新統(tǒng)計(jì)信息,其實(shí)SQL Server不是這樣做的.基于性能考慮,SQL Server使用下面的算法更新統(tǒng)計(jì)信息2012-08-08SQL Report Builder 報(bào)表里面的常見問題分析
這篇文章主要介紹了SQL Report Builder 報(bào)表里面的常見問題分析的相關(guān)資料,需要的朋友可以參考下2015-12-12Navicat連接本地SqlServer出現(xiàn)?[08001][Microsoft][sQL?Server?Nati
這篇文章主要給大家介紹了Navicat連接本地SqlServer出現(xiàn)?[08001][Microsoft][sQL?Server?Native?Client?11.0]命名管道提供程序:無法打開與SQL?Server等錯(cuò)誤的解決方法,需要的朋友可以參考下2023-09-09