MS SQL Server的STRING_SPLIT和STRING_AGG函数

栏目: 数据库 · 发布时间: 5年前

内容简介:在较新版本的SQL中,出现有2个函数,STRING_SPLIT和STRING_AGG,前者是把带有分隔的字符串转换为表,而后者却是把表某一表转换为以某种字符分隔的字符串。如下面:把它转存为表:

在较新版本的 SQL 中,出现有2个函数,STRING_SPLIT和STRING_AGG,前者是把带有分隔的字符串转换为表,而后者却是把表某一表转换为以某种字符分隔的字符串。

如下面:

DECLARE @str NVARCHAR(MAX) = N'ADS,ADFD,AGF,SDFGSFD,DSFG,RET,TRY,T,ADF,GSF,UY,QWERQ'

把它转存为表:

MS SQL Server的STRING_SPLIT和STRING_AGG函数


DECLARE @dump_data AS TABLE([value] NVARCHAR(MAX))
INSERT INTO @dump_data ([value])  SELECT [value] FROM STRING_SPLIT(@str,',')

Source Code

反转,需要把临时表这列[value] 转换为一个字符串:

MS SQL Server的STRING_SPLIT和STRING_AGG函数


SELECT STRING_AGG([value], ',') 
FROM @dump_data

Source Code

其实STRING_AGG这函数,还可以对新串联的字符进行排序:

MS SQL Server的STRING_SPLIT和STRING_AGG函数


SELECT STRING_AGG([value], ',') WITHIN GROUP (ORDER BY [value]) 
FROM @dump_data

Source Code

如果你不想创建临时表,把拆分的数据插入临时表,步骤繁复。可以使用派生表来进行:

MS SQL Server的STRING_SPLIT和STRING_AGG函数


SELECT STRING_AGG([value], ',') WITHIN GROUP (ORDER BY [value]) 
FROM (SELECT [value] FROM STRING_SPLIT(@str,',')) source 

Source Code

或者使用一般资料表运算式CTE (Common Table Expression)

MS SQL Server的STRING_SPLIT和STRING_AGG函数


;WITH dump_data AS
(
    SELECT [value] FROM STRING_SPLIT(@str,',')
)
SELECT STRING_AGG([value], ',') WITHIN GROUP (ORDER BY [value]) 
FROM dump_data;

Source Code

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Hacking Growth

Hacking Growth

Sean Ellis、Morgan Brown / Crown Business / 2017-4-25 / USD 29.00

The definitive playbook by the pioneers of Growth Hacking, one of the hottest business methodologies in Silicon Valley and beyond. It seems hard to believe today, but there was a time when Airbnb w......一起来看看 《Hacking Growth》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试