SQL数据库实训总结 sql查询结果拼接为多列

在做业务数据分析的时候,可能会遇到这样一个场景,需要将多个字段进行拼接 , 变为一个长字符串
比如年、月、日三个字段拼接成完整的日期,或者姓、名两个字段拼接成姓名列
这就需要用到SQL查询中串联(拼接)方法,这在不同数据库中语法会有差异 , 下面会演示MySQL、Oracle、PostgreSQL、SQL Server这四种数据库中的实现方法 。

SQL数据库实训总结 sql查询结果拼接为多列

文章插图
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' , '女');得到数据的形式
SQL数据库实训总结 sql查询结果拼接为多列

文章插图
2、在MySQL中进行串联拼接使用concat函数对不同字段进行拼接 , 用法:
select concat(列1,列2,列3...) from...我们对上表中name、age字段进行串联:
SELECT concat(a.name,'的生日是:',a.age) FROM `students` a结果:
SQL数据库实训总结 sql查询结果拼接为多列

文章插图
2、在PostgreSQL、Oracle中进行串联拼接使用||符号对不同字段进行拼接,用法:
select 列1 || 列2 || 列3... from...我们对上表中name、age字段进行串联:
SELECT a.name || '的生日是:' || a.age FROM students a3、在SQL Server中进行串联拼接使用+符号对不同字段进行拼接,用法:
select 列1 + 列2 + 列3... from...我们对上表中name、age字段进行串联:
SELECT a.name + '的生日是:' + convert(varchar,a.age) FROM students a【SQL数据库实训总结 sql查询结果拼接为多列】这里要注意SQL Server中的+只可以用于字符串类型的字段拼接 , 不能将字符串与数字、日期等其他类型混合拼接,所以如果你想拼接非字符串类型,可以用 convert函数进行字符串的转换 。
当然 SQL Server中的+ 也可以用于数值间的相加 , 也就是加法运算
其他数据库的用法与上述这些大同小异,不再一一列举 。


    以上关于本文的内容,仅作参考!温馨提示:如遇健康、疾病相关的问题,请您及时就医或请专业人士给予相关指导!

    「四川龙网」www.sichuanlong.com小编还为您精选了以下内容,希望对您有所帮助: