1. 程式人生 > 資料庫 >SQL Server分隔函式例項詳解

SQL Server分隔函式例項詳解

有時候我們在SQL Server中需要對一些字串進行分隔,比如a,b,c ,按照‘,'進行分割,可以使用下邊這個函式方法,新建方法如下:

CREATE FUNCTION dbo.f_splitstr(@SourceSql NVARCHAR(MAX),@StrSeprate VARCHAR(100)) 
 RETURNS @temp TABLE(F1 VARCHAR(100)) 
 AS  
 BEGIN 
 DECLARE @ch AS VARCHAR(100) 
 SET @SourceSql=@SourceSql+@StrSeprate  
 WHILE(@SourceSql<>'') 
     BEGIN 
     SET @ch=LEFT(@SourceSql,CHARINDEX(@StrSeprate,@SourceSql,1)-1) 
 INSERT @temp VALUES(@ch) 
 SET @SourceSql=STUFF(@SourceSql,1,1),'') 
     END 
 RETURN 
 END
GO

使用方法:

SELECT * FROM dbo.f_splitstr('a,c',',')

結果:

SQL Server分隔函式例項詳解

這樣我們就實現了對字串的分割處理,當然函式具體內容可以根據我們的需求進行修改。

再和大家多介紹一個,在SQL Server 2016以後,微軟官方加入了一個STRING_SPLIT,也是實現分割函式的,如果你的資料庫版本夠高,可以選擇使用官方的,方法一樣:

SELECT * FROM STRING_SPLIT('a,')

結果:

SQL Server分隔函式例項詳解

總結

到此這篇關於SQL Server分隔函式的文章就介紹到這了,更多相關SQL Server分隔函式內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!