MS SQL Server的STRING_SPLIT和STRING_AGG函数

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

内容简介:在较新版本的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

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

查看所有标签

猜你喜欢:

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

心理学与生活

心理学与生活

[美] 理查德·格里格、菲利普·津巴多 / 王垒、王甦 等 / 人民邮电出版社 / 2003-10 / 88.00元

《心理学与生活》是美国斯坦福大学多年来使用的教材,也是在美国许多大学里推广使用的经典教材,被ETS推荐为GRE心理学专项考试的主要参考用书,还是被许多国家大学的“普通心理学”课程选用的教材。这本教科书写作流畅,通俗易懂,深入生活,把心理学理论与知识联系人们的日常生活与工作,使它同样也成为一般大众了解心理学与自己的极好读物。 作为一本包含着丰富的教育思想和独特教学方法的成熟教材,原书中所有元素......一起来看看 《心理学与生活》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具