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

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

查看所有标签

猜你喜欢:

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

Java语言程序设计

Java语言程序设计

(美) Y. Daniel Liang / 李娜 / 机械工业出版社 / 2011-6 / 79.00元

本书是Java语言的经典教材,畅销多年不衰。本书全面整合了Java的特性,采用“先讲基础”的教学方式,循序渐进地介绍了程序设计基础、面向对象程序设计、GUI程序设计等。另外,本书还全面且深入地覆盖了一些高级主题,包括算法和数据结构、并发、网络、国际化、高级GUI、数据库和Web程序设计等。 本书中文版由《Java语言程序设计 基础篇》和《Java语言程序设计 进阶篇》组成。基础篇对应原书的第......一起来看看 《Java语言程序设计》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

MD5 加密
MD5 加密

MD5 加密工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具