MySQL/Oracle 的 字符串拼接

目录

  • MySQL、Oracle 的 字符串拼接
    • 1、MySQL 的字符串拼接
      • 1.1 CONCAT(str1,str2,...) : 可以拼接多个字符串
      • 1.2 CONCAT_WS(separator,str1,str2,...) : 指定分隔符拼接多个字符串
      • 1.3 GROUP_CONCAT(expr) : 聚合函数,用于将多行的值连接成一个字符串。
    • 2、Oracle 的字符串拼接
      • 2.1 CONCAT(ch1,ch2) : 拼接二个字符串
      • 2.2 WM_CONCAT(column_name) : 用于将字段多行数据拼接成一个字符串。
    • 3、总结

MySQL、Oracle 的 字符串拼接

1、MySQL 的字符串拼接

在这里插入图片描述

1.1 CONCAT(str1,str2,…) : 可以拼接多个字符串

str1,str2:字符串

参考案例:

SELECT CONCAT('A','B','C','...') FROM TEST1; -- 返回: ABC...
SELECT CONCAT('remark: ', REMARK) FROM TEST1; -- 返回: remark: Hello, world!

1.2 CONCAT_WS(separator,str1,str2,…) : 指定分隔符拼接多个字符串

separator:分隔符
str1,str2:字符串

参考案例:

SELECT CONCAT_WS(',','A','B','C','...') FROM TEST1; -- 返回:A,B,C,...

1.3 GROUP_CONCAT(expr) : 聚合函数,用于将多行的值连接成一个字符串。

基本语法:

GROUP_CONCAT(column_name ORDER BY some_column ASC/DESC SEPARATOR ', ')

参考案例:
在这里插入图片描述

SELECT GROUP_CONCAT(STR) FROM TEST1 WHERE ID!=5; -- 返回:apple,banana,orange,grape

注意事项:
(1)GROUP_CONCAT 的默认分隔符是逗号(,),可以使用 SEPARATOR 子句更改它。
(2)结果默认有一个最大长度(通常是 1024 字符),可以通过设置 group_concat_max_len 系统变量来更改这个限制。如果结果超过了这个长度,它将被截断。
(3)当与 GROUP_CONCAT 一起使用时,ORDER BY 子句决定结果的顺序。

2、Oracle 的字符串拼接

在这里插入图片描述

2.1 CONCAT(ch1,ch2) : 拼接二个字符串

ch1,ch2:字符串

参考案例:

SELECT CONCAT('A','B') FROM TEST1; -- 返回: AB
SELECT CONCAT(CONCAT('A','B'),'C') FROM TEST1; -- 返回:ABC

2.2 WM_CONCAT(column_name) : 用于将字段多行数据拼接成一个字符串。

column_name:要拼接的列名,
table_name:表名
基本语法:

SELECT WM_CONCAT(column_name) FROM table_name;

参考案例:
在这里插入图片描述

SELECT WM_CONCAT(STR)  FROM TEST1 WHERE ID!=5;  -- 返回:apple,banana,orange,grape

注意:WM_CONCAT函数在较新的Oracle版本中已被弃用。

3、总结

(1)MySQL 的 CONCAT(str1,str2,…) 和 Oracle 的 str1||str2||… 效果是一致的,可以拼接多个字符串。
(2)Oracle 的 CONCAT(ch1,ch2) 只能拼接二个字符串。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/628081.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#灵活控制多线程的状态(开始暂停继续取消)

ManualResetEvent类 ManualResetEvent是一个同步基元,用于在多线程环境中协调线程的执行。它提供了两种状态:终止状态和非终止状态。 在终止状态下,ManualResetEvent允许线程继续执行。而在非终止状态下,ManualResetEvent会阻塞线…

Python画球面投影图

天文学研究中,有时候需要画的并不是传统的XYZ坐标系,而是需要画一个形如这样子的球面投影图: 下面讲一下这种图怎么画 1. 首先要安装healpy包 pip install healpy 2. 然后导入包 如果之前安装过healpy,有的会提示不存在healpy…

【蓝桥杯日记】第一篇——如何搭建系统环境

目录 前言 环境相关文件 学生机环境-Web应用开发环境(第十五届大赛) 学生机环境-Java编程环境(第十五届大赛) 学生机环境-C/C编程环境(第十五届大赛) 学生机环境-Python编程环境 (第十五届…

20240112让移远mini-PCIE接口的4G模块EC20在Firefly的AIO-3399J开发板的Android11下跑通【DTS部分】

20240112让移远mini-PCIE接口的4G模块EC20在Firefly的AIO-3399J开发板的Android11下跑通【DTS部分】 2024/1/12 16:20 https://blog.csdn.net/u010164190/article/details/79096345 [Android6.0][RK3399] PCIe 接口 4G模块 EC20 调试记录 https://blog.csdn.net/hnjztyx/artic…

【Linux】线程池实现

📗线程池实现(单例模式) 1️⃣线程池概念2️⃣线程池代码样例3️⃣部分问题与细节🔸类成员函数参数列表中隐含的this指针🔸单例模式🔸一个失误导致的bug 4️⃣调用线程池完成任务 1️⃣线程池概念 线程池是…

【Linux驱动】设备树中指定中断 | 驱动中获得中断 | 按键中断实验

🐱作者:一只大喵咪1201 🐱专栏:《Linux驱动》 🔥格言:你只管努力,剩下的交给时间! 目录 🏀在设备树中指定中断🏀代码中获得中断🏀按键中断⚽驱动…

闪存剩下内容

1:通过Arduino IDE向闪存文件系统上传文件 1. 下载 Arduino-ESP8266闪存文件插件程序 2:使用闪存文件系统建立功能更加丰富的网络服务器 1:在网页中加载闪存文件系统中的图片、CSS和JavaScript index.html:ESP8266开发板建立的网…

SpringBoot+SSM项目实战 苍穹外卖(12) Apache POI

继续上一节的内容,本节是苍穹外卖后端开发的最后一节,本节学习Apache POI,完成工作台、数据导出功能。 目录 工作台Apache POI入门案例 导出运营数据Excel报表 工作台 工作台是系统运营的数据看板,并提供快捷操作入口&#xff0c…

初识OpenCV

首先你得保证你的虚拟机Ubuntu能上网 可看 http://t.csdnimg.cn/bZs6c 打开终端输入 sudo apt-get install libopencv-dev 回车 输入密码 回车 遇到Y/N 回车 OpenCV在线文档 opencv 文档链接 点zip可以下载,点前面的直接在线浏览,但是很慢 https…

单元测试:Testing leads to failure, and failure leads to understanding

单元测试的概念可能多数读者都有接触过。作为开发人员,我们编写一个个测试用例,测试框架发现这些测试用例,将它们组装成测试 suite 并运行,收集测试报告,并且提供测试基础设施(断言、mock、setup 和 teardo…

JAVAEE初阶 文件IO(一)

这里写目录标题 一. 计算机中存储数据的设备1.1 CPU1.2 内存1.3 硬盘1.4 三种存储的区别 二.文件系统2.1 相对路径2.2 绝对路径2.3 .和..的含义2.4 例子2.5 everything工具 三.文件3.1 文本文件3.2 二进制文件 四. JAVA对于文件的API4.1 getParent getName getPath getAbsolute…

Jest单元测试:玩转代码的小捉迷藏!

Jest Jest 是什么? Jest 是一个流行的 JavaScript 测试框架,专注于简化和改进代码的测试流程。它由 Facebook 开发并维护,具有以下特点: 1、易用性:Jest 提供了一个简单而强大的测试框架,使得编写和运行测…

uniapp h5 发行后 微信第二次打开网址 页面白屏

发行后把网址给客户,第一次可以正常登录打开,第二次打开白屏 原因:第一次打开时没有token,所以跳转登录页,可以正常访问 第二次打开时有token,但是网址根目录没有配置默认页面,所以白屏 解决…

Windows Server调整策略实现999999个远程用户用时登录

正文共:1234 字 23 图,预估阅读时间:2 分钟 上篇文章中(Windows Server 2019配置多用户远程桌面登录服务器),我们主要介绍了Windows Server 2019在配置远程桌面时,如何通过3种方式创建本地用户账…

使用Qt连接scrcpy-server控制手机

Qt连接scrcpy-server 测试环境如何启动scrcpy-server1. 连接设备2. 推送scrcpy-server到手机上3. 建立Adb隧道连接4. 启动服务5. 关闭服务 使用QTcpServer与scrcpy-server建立连接建立连接并视频推流完整流程1. 开启视频推流过程2. 关闭视频推流过程 视频流的解码1. 数据包协议…

NVMe系统内存结构 - Meta Data

NVMe系统内存结构 - Meta Data 1 为什么需要数据保护2 Meta Data定义3 Meta Data传输方式4 常见Meta Data使用场景4.1 不带数据保护信息4.2 带数据保护信息“数据写”流程4.3 带数据保护信息“数据读”流程4.4 SSD内部加入数据保护信息4.5 SSD内部根据数据保护信息验证数据 本文…

如何在你的网站接入QQ登录?

文章目录 准备阶段申请QQ登录的权限创建应用最后上传qqlogin.php代码 准备阶段 国内服务器和备案域名需要你有张独一无二本人的身份证你正面手持身份证的图片一张100px*100px的网站图标 申请QQ登录的权限 首先访问qq互联,点击我直接访问 登陆完成后我们点击面的…

bash shell基础命令(一)

1.shell启动 shell提供了对Linux系统的交互式访问,通常在用户登录终端时启动。系统启动的shell程序取决于用户账户的配置。 /etc/passwd/文件包含了所有用户的基本信息配置, $ cat /etc/passwd root:x:0:0:root:/root:/bin/bash ...例如上述root账户信…

Python新年文字烟花简单代码

简单的Python新年烟花代码示例: import random import timedef create_firework():colors [红色, 橙色, 黄色, 绿色, 蓝色, 紫色]flashes [爆裂, 闪光, 旋转, 流星, 喷射]color random.choice(colors)flash random.choice(flashes)print(f"发射一枚{color…

redis之单线程和多线程

目录 1、redis的发展史 2、redis为什么选择单线程? 3、主线程和Io线程是怎么协作完成请求处理的? 4、IO多路复用 5、开启redis多线程 1、redis的发展史 Redis4.0之前是用的单线程,4.0以后逐渐支持多线程 Redis4.0之前一直采用单线程的主…