SQL语法精选-如何拼接多列的值?
创始人
2025-01-11 11:33:14
0

在做业务数据分析的时候,可能会遇到这样一个场景,需要将多个字段进行拼接,变为一个长字符串

比如年、月、日三个字段拼接成完整的日期,或者姓、名两个字段拼接成姓名列

这就需要用到SQL查询中串联(拼接)方法,这在不同数据库中语法会有差异,下面会演示MySQL、Oracle、PostgreSQL、SQL Server这四种数据库中的实现方法。

1、插入数据

这里用的是MySQL数据库,插入原始数据,用于后面的实验

其他数据库的插入语法,可能会有细微差别,可自行调整

CREATE TABLE IF NOT EXISTS `students` (   `id` varchar(10) NOT NULL,   `name` varchar(10) NOT NULL,   `age` datetime NOT NULL,   `sex` varchar(10) NOT NULL,   PRIMARY KEY (`id`) ) DEFAULT CHARSET=utf8;  insert into `students` values('01' , '赵雷' , '1990-01-01' , '男'); insert into `students` values('02' , '钱电' , '1990-12-21' , '男'); insert into `students` values('03' , '孙风' , '1990-05-20' , '男'); insert into `students` values('04' , '李云' , '1990-08-06' , '男'); insert into `students` values('05' , '周梅' , '1991-12-01' , '女');  

得到数据的形式

2、在MySQL中进行串联拼接

使用concat函数对不同字段进行拼接,用法:

select concat(列1,列2,列3...) from...    

我们对上表中name、age字段进行串联:

SELECT concat(a.name,'的生日是:',a.age) FROM `students` a  

结果:

2、在PostgreSQL、Oracle中进行串联拼接

使用||符号对不同字段进行拼接,用法:

select 列1 || 列2 || 列3... from...  

我们对上表中name、age字段进行串联:

SELECT a.name || '的生日是:' || a.age FROM students a  

3、在SQL Server中进行串联拼接

使用+符号对不同字段进行拼接,用法:

select 列1 + 列2 + 列3... from...  

我们对上表中name、age字段进行串联:

SELECT a.name + '的生日是:' + convert(varchar,a.age) FROM students a  

这里要注意SQL Server中的+只可以用于字符串类型的字段拼接,不能将字符串与数字、日期等其他类型混合拼接,所以如果你想拼接非字符串类型,可以用 convert函数进行字符串的转换。

当然 SQL Server中的+ 也可以用于数值间的相加,也就是加法运算

相关内容

热门资讯

黑科技辅助!wpk辅助神器(透... 黑科技辅助!wpk辅助神器(透视)软件透明辅助挂(本来是真的有挂)-哔哩哔哩是一款可以让一直输的玩家...
5分钟了解“创思维正版辅助器下... 5分钟了解“创思维正版辅助器下载”详细透视开挂辅助安装-哔哩哔哩;一、创思维正版辅助器下载有挂的是的...
两分钟科普!wpk真吗,哈糖大... 两分钟科普!wpk真吗,哈糖大菠萝可以开挂吗,曝光教程(发现有挂)-哔哩哔哩哈糖大菠萝可以开挂吗辅助...
第一分钟了解(昆仑大厅)外挂辅... 第一分钟了解(昆仑大厅)外挂辅助插件(透视)详细教程(2022已更新)(哔哩哔哩);亲真的是有正版授...
黑科技辅助!wpk俱乐部长期盈... 黑科技辅助!wpk俱乐部长期盈利打法(透视)软件透明挂黑科技(切实存在有挂)-哔哩哔哩;1、让任何用...
第6分钟了解“功夫川嘛辅助器”... 第6分钟了解“功夫川嘛辅助器”详细透视开挂辅助器-哔哩哔哩;人气非常高,ai更新快且高清可以动的一个...
第五分钟辅助!xpoker辅助... 第五分钟辅助!xpoker辅助,德州透视插件,攻略教程(有挂方法)-哔哩哔哩德州透视插件辅助器中分为...
两分钟了解(皮皮跑胡子)外挂透... 两分钟了解(皮皮跑胡子)外挂透明挂辅助工具(辅助挂)透明挂教程(2020已更新)(哔哩哔哩);皮皮跑...
黑科技辅助!微扑克可以加入俱乐... 您好,微扑克可以加入俱乐部这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩...
8分钟了解“掌中乐游戏中心辅助... 8分钟了解“掌中乐游戏中心辅助器”详细透视开挂辅助脚本-哔哩哔哩;1、这是跨平台的掌中乐游戏中心辅助...