[SQL Server][T-SQL]STRING_AGG数据集组成字符串(SQL Server 2017)
时间:2019-09-05
本文章向大家介绍[SQL Server][T-SQL]STRING_AGG数据集组成字符串(SQL Server 2017),主要包括[SQL Server][T-SQL]STRING_AGG数据集组成字符串(SQL Server 2017)使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
SQL Server 2016推出了将字符串分割成数据集(STRING_SPLIT)的功能,今年SQL Server 2017则推出了将数据集组成字符串的串接功能(STRING_AGG),而且还支持简单的分组和排序,今晚继续吃第三颗语法糖(胖)。
建立测试环境
CREATE TABLE F1Driver (
id INT IDENTITY(1, 1) NOT NULL,
name NVARCHAR(50),
team NVARCHAR(50),
PRIMARY KEY (id)
);
INSERT INTO F1Driver (name,team) VALUES
(N'L. Hamilton',N'Mercedes AMG')
,(N'S. Vettel',N'Ferrari')
,(N'K. Räikkönen',N'Ferrari')
,(N'V. Bottas',N'Mercedes AMG')
SELECT * from F1Driver
查询测试数据表
好,车手和车队的简单测试环境有了!
回传1笔数据
L. Hamilton,S. Vettel,K. Räikkönen,V. Bottas
SELECT
STRING_AGG(name, ',')
FROM F1Driver
简单的使用STRING_AGG就能实现。
希望按照F1车队分组,然后返回2笔数据
S. Vettel,K. Räikkönen
V. Bottas,L. Hamilton
SELECT STRING_AGG (name,',')
FROM F1Driver
GROUP BY team
希望按照车队分组,但组合字符串时,要以车手的id降幂序组成。
K. Räikkönen,S. Vettel
V. Bottas,L. Hamilton
SELECT STRING_AGG (name,',')
WITHIN GROUP (ORDER BY id desc)
FROM F1Driver
GROUP BY team
加上WITHIN GROUP
两个车队的二号车手都可以排在前面了。
2017新加坡F1是Hamilton冠军了!生涯第60胜。
小结
- SQL 2016 STRING_SPLIT + SQL 2017 STRING_AGG
- 天下大势,分久必合,合久必分。
- SQL 2017之前可以参考这篇[SQL Server][T-SQL]将多笔数据列串接成单一字段的复合字符串来替代STRING_AGG功能。
参考
STRING_AGG (Transact-SQL)
STRING_SPLIT (Transact-SQL)
[SQL Server][T-SQL]将多笔数据列串接成单一字段的复合字符串。
原文:大专栏 [SQL Server][T-SQL]STRING_AGG数据集组成字符串(SQL Server 2017)
原文地址:https://www.cnblogs.com/petewell/p/11465521.html
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解
- oracle数据库impdp导入dmp文件功能演示,imp导入IMP-00038: Could not convert to environment character sets handle问题解决
- 弄懂这 5 个问题,拿下 Python 迭代器!
- windows、linux下命令行登录oracle数据库方法,查询sga参数值sql语句
- oracle数据库查询open_cursors值的sql语句,达梦数据库查询MAX_SESSION_STATEMENT值方法,MAX_SESSION_STATEMENT的最大值、上限是多少。
- 达梦数据库启用日志方法,达梦数据库查看日志是否启用,达梦数据库日志文件位置查找
- JavaScript 技术篇 - js 查看哪个元素获取了焦点,js 指定元素获取焦点方法
- 工作10年后,再看String s = new String("xyz") 创建了几个对象?
- Linux达梦数据库:通过disql登录命令行操作数据库,打开达梦数据库自带的数据库管理连接工具
- Dbvis数据库连接工具将查询出数据转化为sql插入语句方法
- JavaScript 技术篇 - js通过xpath路径定位元素方法
- Python+selenium 自动化高级应用篇:借助pyautogui实现web前端带轨迹拖拽功能,解决ActionChains拖拽失效问题
- PG数据库版本查看方法,sql语句查pg数据库版本方法
- Linux下DM达梦数据库导入导出dmp文件实战演示,dexp和dimp命令详细使用方法
- oracle数据库imp导入失败提示:“不是有效的导出文件, 标头验证失败”解决方法,修改dmp文件里oracle数据库版本号方法
- BAT批处理文件无法运行提示“/E /I /Y ‘XCOPY‘ 不是内部或外部命令,也不是可运行的程序或批处理文件”解决方法