日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

中统计字符串长度的函数_SQL Server中的字符串分割函数

發布時間:2023/12/2 数据库 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 中统计字符串长度的函数_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中的字符串分割函数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。