网站首页 > 技术文章 正文
在做业务数据分析的时候,可能会遇到这样一个场景,需要将多个字段进行拼接,变为一个长字符串
比如年、月、日三个字段拼接成完整的日期,或者姓、名两个字段拼接成姓名列
这就需要用到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中的+ 也可以用于数值间的相加,也就是加法运算
其他数据库的用法与上述这些大同小异,不再一一列举。
猜你喜欢
- 2024-10-23 OGG同步到Kafka ogg kafka flink
- 2024-10-23 【oracle】无法从套接字读取更多数据
- 2024-10-23 Oracle的TNS协议解析 oracle tns错误
- 2024-10-23 两种方式中断会话连接oracle oracle怎么中断查询
- 2024-10-23 常用SQL系列之(三):记录叠加、匹配、外连接及笛卡尔等
- 2024-10-23 Oracle交集(intersect),并集(union union all ),差集(minus)区别
- 2024-10-23 python3.13下使用数据库连接池 pymysql数据库连接池
- 2024-10-23 Oracle数据库-TNS连接 oracle 数据库tns配置
- 2024-10-23 oracle 如何将显示结果合并成一列
- 2024-10-23 oracle——xmlagg拼接大字段问题 oracle拼接字段展示
你 发表评论:
欢迎- 547℃Oracle分析函数之Lag和Lead()使用
- 544℃几个Oracle空值处理函数 oracle处理null值的函数
- 542℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 535℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 531℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 517℃【数据统计分析】详解Oracle分组函数之CUBE
- 505℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 493℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端排序 (47)
- 前端密码加密 (47)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)