美文网首页技术
SQL语法精选-如何拼接多列的值?

SQL语法精选-如何拼接多列的值?

作者: 朱卫军AI_Python | 来源:发表于2022-03-20 10:31 被阅读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中的+ 也可以用于数值间的相加,也就是加法运算

相关文章

  • SQL语法精选-如何拼接多列的值?

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

  • SQL 函数

    1.SQL AVG 函数 ===> 返回数值列的平均值。NULL 值不包括在计算中 语法: 实例: 2.SQL C...

  • MyBatis动态sql

    动态sql就是可以对sql语句进行灵活的封装,拼接。通过mybatis语法的判断可以实现动态sql。 1 if标签...

  • 聊聊mysql的多列组合查询

    序 本文主要展示如何使用mysql的多列组合查询 何为多列组合查询呢,就是查询的值不再是单个列的值,而是组合列的值...

  • sql语法:sql必读必会(二)mysql中的函数大全

    SQL 函数 AVG 函数作用:AVG 函数返回数值列的平均值。NULL 值不包括在计算中语法:SELECT AV...

  • 2018-12-23 MyBatis SQL无语法错误出现报错的

    问题描述:MyBatis动态SQl 使用如下语句时,在最终的拼接中产生了 sql语法错误

  • MyBatis动态SQL

    动态 SQL 是 MyBatis 的强大特性之一。根据不同条件拼接 SQL 语句有多痛苦,例如拼接时要确保不能忘记...

  • 2019-07-08 MYSQL 批量将一个表的多行多列更新到另

    子查询方式:此方式需要在值中使用SQL,并且一个sql只能对应一个值,不建议使用。 同时多列更新方案(推荐): 在...

  • MySQL 删除

    MySQL UPDATE也是SQL最常用的语句之一用来修改数据,可更新行中一列或多列数据。我们先来看下语法 注意:...

  • 读书笔记《sql必知必会》

    检索 最简单的查询语句 排序 降序 升序 过滤 高级 利用多列组合进行过滤(拼接字段): 其中RTRIM函数去掉值...

网友评论

    本文标题:SQL语法精选-如何拼接多列的值?

    本文链接:https://www.haomeiwen.com/subject/qtmodrtx.html