【SQL Server】concat、concat_ws、group_concat用法

本文介绍了SQL Server中用于字符串连接的三个函数:concat、concat_ws和group_concat。concat函数可以连接多个字符串,concat_ws在连接时允许设置分隔符。group_concat则在分组后连接字符串,常与group by语句配合使用,并可自定义分隔符和排序。示例中展示了如何使用这些函数,并给出了不同的用法和参数设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

concat
用途:连接一个或多个字符串
语法:concat(str1,str2…)
eg:

>>>select concat('aa','bb','cc')
>aabbcc

concat_ws
用途:使用固定连接符连接一个或多个字符串
语法:concat(separator,str1,str2…)
eg:

>>>select concat_ws('-','aa','bb','cc')
>aa-bb-cc

group_concat
用途:分组连接一个或多个字符串
语法:group_concat([DISTINCT] 连接字段名 [Order BY ASC/DESC 排序字段] [Separator ‘分隔符’])
注意:需要和group by结合使用
eg:

CREATE TABLE student_courses (     
    student_id INT UNSIGNED NOT NULL,     
    courses_id INT UNSIGNED NOT NULL,     
    KEY(student_id)     
);     
INSERT INTO student_courses VALUES (1, 1), (1, 2), (2, 3), (2, 4), (2, 5); 

eg:查找学生ID为2所选的课程

SELECT student_id, courses_id FROM student_courses WHERE student_id=2

在这里插入图片描述

SELECT student_id, GROUP_CONCAT(courses_id) AS courses 
FROM student_courses WHERE student_id=2 GROUP BY student_id

在这里插入图片描述
分隔符还可以自定义,默认是以“,”作为分隔符,若要改为“|||”,则使用SEPARATOR来指定,例如:

SELECT student_id, GROUP_CONCAT(courses_id SEPARATOR '|||') AS courses 
FROM student_courses WHERE student_id=2 GROUP BY student_id

除此之外,还可以对这个组的值来进行排序再连接成字符串,例如按courses_id降序来排:

SELECT student_id, GROUP_CONCAT(courses_id ORDER BY courses_id DESC) AS courses 
FROM student_courses WHERE student_id=2 GROUP BY student_id
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值