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中的+ 也可以用于数值间的相加,也就是加法运算

相关内容

热门资讯

模块辅助!全民比鸡手游辅助(辅... 模块辅助!全民比鸡手游辅助(辅助)切实有辅助方法(哔哩哔哩)1、超多福利:超高返利,海量正版游戏,全...
指南书辅助!开心泉州辅助器ap... 指南书辅助!开心泉州辅助器app下载(辅助)竟然真的是有辅助app(哔哩哔哩)1、开心泉州辅助器ap...
演示辅助!陕麻圈有辅助吗(辅助... 演示辅助!陕麻圈有辅助吗(辅助)一贯一直都是有辅助app(哔哩哔哩)1、陕麻圈有辅助吗模拟器是什么优...
要领辅助!新道游智能辅助器(辅... 要领辅助!新道游智能辅助器(辅助)一直存在有辅助教程(哔哩哔哩)新道游智能辅助器辅助器是一种具有地方...
攻略辅助!微信小程序锄大地辅助... 您好,微信小程序锄大地辅助这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很...
策略辅助!胡乐辅助脚本有哪些常... 策略辅助!胡乐辅助脚本有哪些常见功能(辅助)一贯真的有辅助工具(哔哩哔哩)在进入胡乐辅助脚本有哪些常...
教程书辅助!陕麻全黑科技(辅助... 教程书辅助!陕麻全黑科技(辅助)一直真的是有辅助攻略(哔哩哔哩)1、陕麻全黑科技辅助器安装包、陕麻全...
操作辅助!中至上饶里的祈福有用... 操作辅助!中至上饶里的祈福有用吗(辅助)原来一直都是有辅助技巧(哔哩哔哩)1、该软件可以轻松地帮助玩...
方式辅助!传送屋辅助器下载(辅... 方式辅助!传送屋辅助器下载(辅助)总是是有辅助神器(哔哩哔哩)1、传送屋辅助器下载公共底牌简单,传送...
讲义辅助!微乐山西脚本插件(辅... 讲义辅助!微乐山西脚本插件(辅助)其实真的是有辅助神器(哔哩哔哩)1、微乐山西脚本插件模拟器是什么优...