我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SQL字符串的合并与拆分实例代码分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SQL字符串的合并与拆分实例代码分析

本篇内容主要讲解“SQL字符串的合并与拆分实例代码分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SQL字符串的合并与拆分实例代码分析”吧!

字符串的合并

SQL字符串的合并与拆分实例代码分析

SQL字符串的合并与拆分实例代码分析

在Oracle中可能有多种实现方法,目前我已知的有两种,下面记录下这两种的实现:

字符串合并方法一:

实现SQL:

--方法一
SELECT d.dept_name,wm_concat(e.emp_name) FROM employee e
INNER JOIN department d ON d.dept_id=e.dept_id
GROUP BY d.dept_name;

执行结果:

SQL字符串的合并与拆分实例代码分析

SQL分析:

利用Oracle自带的wm_concat()函数将字符串合并,这里有个缺点,合并的连接符号只能为默认的逗号,不能用其他符号。

字符串合并方法二:

实现SQL:

--方法二
SELECT d.dept_name,
LISTAGG (e.emp_name, ',') WITHIN GROUP (ORDER BY e.emp_name) names
FROM employee e
INNER JOIN department d ON d.dept_id=e.dept_id
GROUP BY d.dept_name;

执行结果:

SQL字符串的合并与拆分实例代码分析

SQL分析:

利用Oracle自带的LISTAGG()函数将字符串合并,它的优点在于,合并的连接符号可以指定为任意字符,并且可以很方便实现ORDER BY排序。

字符串的拆分

SQL字符串的合并与拆分实例代码分析

SQL字符串的合并与拆分实例代码分析

在Oracle中可能有多种实现方法,目前我已知的有两种,下面记录下这两种的实现:

字符串拆分方法一:

实现SQL:

--方法一
WITH  t (id, name, sub, str) AS (
    SELECT id, name, substr(class, 1, instr(class, '、')-1), substr(concat(class,'、'), instr(class, '、')+1) 
    FROM movies
    
    UNION ALL
    
    SELECT id, name,substr(str, 1, instr(str, '、')-1), substr(str, instr(str, '、')+1)
    FROM t WHERE instr(str, '、')>0
) 
 
SELECT id, name, sub
FROM t
ORDER BY id;

执行结果:

SQL字符串的合并与拆分实例代码分析

SQL分析:

这个语句稍微有些复杂,下面分步骤进行说明:

首先看下movies表的原始数据:

SQL字符串的合并与拆分实例代码分析

1.第一步是将class字段的值根据分隔符(此处为顿号)进行初步拆分,拆分为两个部分。第一部分为class字段要拆分的第一个值,第二部分为class字段要拆分的其余部分的值。

SQL字符串的合并与拆分实例代码分析

2.第二步利用WITH表达式实现递归查询,根据分隔符(此处为顿号)循环将第一步操作中未拆分的值(第二部分)进行拆分,一直拆分到字段的最后一个分割符为止,递归结束的数据放在临时表t中。

SQL字符串的合并与拆分实例代码分析

3.第三步是一个简单的查询,从第二步的临时表t中查询记录并排序。

SQL字符串的合并与拆分实例代码分析

字符串拆分方法二:

实现SQL:

--方法二
SELECT m.name,t.column_value FROM movies m,TABLE(SPLIT(m.class,'、')) t;

执行结果:

SQL字符串的合并与拆分实例代码分析

SQL分析:

这种方法其实是通过自定义一个函数(function)来处理字符串,函数split的逻辑其实跟方法一的逻辑差不多,都是用到了递归,将字符串中的值根据分隔符一次一次拆分,最终返回拆分后的字符串。这种方法个人感觉更好一些,因为是将拆分逻辑进行了封装,使用起来更简单,逻辑更清晰。

下面是split函数的创建脚本:

create or replace function split (p_list clob, p_sep varchar2 := ',')
  return tabletype
  pipelined
 
is
  l_idx    pls_integer;
  v_list  varchar2 (32676) := to_char(p_list);
begin
  loop
      l_idx  := instr (v_list, p_sep);
 
      if l_idx > 0
      then
        pipe row (substr (v_list, 1, l_idx - 1));
        v_list  := substr (v_list, l_idx + length (p_sep));
      else
        pipe row (v_list);
        exit;
      end if;
  end loop;
end;

函数的返回值类型tabletype也是自定义的一个类型。

下面是该类型的创建脚本:

create or replace type tabletype as table of varchar2(32676);

到此,相信大家对“SQL字符串的合并与拆分实例代码分析”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SQL字符串的合并与拆分实例代码分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

sql拆分字符串实现一行变多行的实例代码

目录一、需求一、pg数据库中一行变多行二、mysql数据库中一行变多行2.1 实现方式2.2 递归方式2.3 方式二 一、需求1 某一个字段中的数据为字符串拼接,要求按照特定分隔符分割成多行2 例如(movies)表拆分结果编程网为
sql拆分字符串实现一行变多行的实例代码
2024-09-07

怎么在python拆分与合并字符串

这篇文章将为大家详细讲解有关怎么在python拆分与合并字符串,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。python有哪些常用库python常用的库:1.requesuts;2.scra
2023-06-14

MySQL 字符串拆分实例(无分隔符的字符串截取)

无分隔符的字符串截取 题目要求 数据库中字段值:实现效果:需要将一行数据变成多行实现的sqlSELECT LEFT(SUBSTRING('P1111',help_topic_id+1),1) AS num FROM mysql.help_t
2022-05-30

Python字符串的字符转换、字符串劈分、字符串合并问题分析

这篇文章主要介绍了Python字符串的字符转换、字符串劈分、字符串合并,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-03-20

MySQL字符串拼接与分组拼接字符串实例代码

目录一、经典拼接concat(x,x,....)二、分隔符拼接CONCAT_WS(separator,str1,str2,...)三、分组拼接GROUP_CONCAT(expr)补充:在筛选查询中进行字符串拼接并显示在表格里总结一、经典拼接
2023-02-02

pyspark dataframe列的合并与拆分实例

这篇文章主要介绍了pyspark dataframe列的合并与拆分实例,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-03-23

mysql拆分字符串作为查询条件的示例代码

目录mysql.help_topicREPLACELENGHTsubstring_index分析有个群友问一个问题这表的ancestors列存放的是所有的祖先节点,以,分隔例如我查询dept_id为103的所有祖先节点,现在我只有一个de
2022-07-06

MySQL按指定字符合并以及拆分实例教程

前言 按照指定字符进行合并或拆分是经常碰到的场景,MySQL在合并的写法上比较简单,但是按指定字符拆分相对比较麻烦一点(也就是要多写一些字符)。本文将举例演示如何进行按照指定字符合并及拆分。 1、 合并 MySQL数据库中按照指定字符合并可
2022-05-23

Python中拆分具有多个分隔符的字符串方法实例

str.split()是Python中字符串类型的一个方法,可以用来将字符串按照指定的分隔符分割成多个子字符串,这篇文章主要给大家介绍了关于Python中拆分具有多个分隔符的字符串的相关资料,需要的朋友可以参考下
2023-05-18

Python字符串的索引与切片实例分析

这篇“Python字符串的索引与切片实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python字符串的索引与切片实例
2023-06-29

Oracle中分割字符串的方法实例代码

目录1. 使用 regexp_substr() 函数1.1 方式11.2 方式21.3 注意问题(尤其是存储过程中用到,可能会入坑)2. 自定义函数2.1 自定义类型 table2.2 自定义函数2.2.1 自定义函数2.2.2 效果如下:
2023-02-15

python字典合并操作符的示例分析

这篇文章主要介绍了python字典合并操作符的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。python的五大特点是什么python的五大特点:1.简单易学,开发程序
2023-06-14

Python字符串,列表,字典和集合实例处理分析

今天小编给大家分享一下Python字符串,列表,字典和集合实例处理分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.如何
2023-07-02

编程热搜

目录