中统计字符串长度的函数_SQL Server中的字符串分割函数
生活随笔
收集整理的這篇文章主要介紹了
中统计字符串长度的函数_SQL Server中的字符串分割函数
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
您是否知道從SQL Server 2016開始,系統就內置STRING_SPLIT函數,該函數用于將字符串分隔的變量拆分為一個可用列表。 對于經常需要分割字符串的技術人員,建議您查看此功能。 STRING_SPLIT是一個表值函數,它返回由定界符分隔的字符串值的單個列。 這是T-SQL的不尋常之處,其使用要求兼容級別為130或更高(Microsoft不想引起對現有用戶代碼的重大更改)。 使用此方法效率更高,并且可以在不調用標量函數的情況下執行。
SQL Server系統內置分割函數
語法
STRING_SPLIT(字符串、分隔符)
如何使用它呢?
SELECT value AS 'Flavor' FROM STRING_SPLIT('Chocolate,Vanilla,Strawberry', ',');返回結果
執行計劃是這樣子的,它非常直接和簡單。
自定義函數
這是在某些環境中可以找到的本地版本,您可以看到它的效率低得多。
****** Object: UserDefinedFunction [dbo].[fnSplit] Script Date: 7/11/2020 10:26:45 AM ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO ALTER FUNCTION [dbo].[fnSplit]( @sInputList VARCHAR(8000) -- List of delimited items , @sDelimiter VARCHAR(8000) = ',' -- delimiter that separates items ) RETURNS @List TABLE (item VARCHAR(8000)) BEGIN DECLARE @sItem VARCHAR(8000) WHILE CHARINDEX(@sDelimiter,@sInputList,0) <> 0 BEGIN SELECT @sItem=RTRIM(LTRIM(SUBSTRING(@sInputList,1,CHARINDEX(@sDelimiter,@sInputList,0)-1))), @sInputList=RTRIM(LTRIM(SUBSTRING(@sInputList,CHARINDEX(@sDelimiter,@sInputList,0)+LEN(@sDelimiter),LEN(@sInputList)))) IF LEN(@sItem) > 0 INSERT INTO @List SELECT @sItem END IF LEN(@sInputList) > 0 INSERT INTO @List SELECT @sInputList -- Put the last item in RETURN END結果
結果是一樣的。但是請注意,您的字段名每次都是相同的,有了這個新函數,您在這方面獲得了更多的靈活性。
執行計劃
它比我們上面看到的包含序列的直接表達式要復雜一些。
有許多不同的方法可以編寫這樣一個分割函數,但是既然SQL Server已經提供了一個,我強烈建議您看看它。
總結
以上是生活随笔為你收集整理的中统计字符串长度的函数_SQL Server中的字符串分割函数的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 时间序列的截尾和拖尾_R语言:时间序列(
- 下一篇: spring mvc mysql 实例_