sql拆分字符串实现一行变多行的实例代码
目录
- 一、需求
- 一、pg数据库中一行变多行
- 二、mysql数据库中一行变多行
- 2.1 实现方式
- 2.2 递归方式
- 2.3 方式二
一、需求
1 某一个字段中的数据为字符串拼接,要求按照特定分隔符分割成多行
2 例如(movies)表
拆分结果为:
一、pg数据库中一行变多行
1 在pg数据库中实现这种拆分有指定的函数:UNNEST(STRING_TO_ARRAY(字段,'分隔符'))。
2 STRING_TO_ARRAY(字段,‘分隔符’);将字符串 -----> {字符串} 数组。
3 UNNEST 将数组拆分
4 代码
SELECT
id,name,hobbies,
UNNEST(string_to_array(hobbies, '、')) as tmp
FROM movies
二、mysql数据库中一行变多行
注:mysql 中没有指定的函数来实现数据库中一行变多行。
2.1 实现方式
(1)利用递归不停的循环拆分 -- (mysql版本必须在5.8+ 才可以用)
(2)利用一个临时表。要求:临时表中某一个字段的值必须是int类型且是联系递增的。
2.2 递归方式
1 代码实现
WITH RECURSIVE m(id,name,hobbies,str) AS (
SELECT id,name,substr(hobbies,1,instr(hobbies,'、')-1),suubstr(concat(class,'、'),instr(class,'、')+1)
FROM movies m
UNION ALL
SELECT id,name,substr(str,1,instr(str,'、')-1),suubstr(str,instr(class,'、')+1)
FROM m
WHERE instr(str,'、')>0
)
SELECT * FROM m ORDER BY id;
2.3 方式二
1 实现思路:我们利用substring_index函数按照指定分隔符截取字符串。
2 substring_index(str,delimiter,number) 返回从字符串 str 的第 number 个出现的分隔符 delimiter 之前的子串。
3 如果 number 是正数,那么就是从左往右,返回第 number 个分隔符的左边的全部内容;number为负,则相反。例如 substring_index(hobbies,'、',2),获得的结果为:
id | name | hobbies | sub |
1 | 千与千寻 | 动画、剧情、奇幻 | 动画、剧情 |
2 | 阿甘正传 | 剧情、爱情 | 剧情、爱情 |
3 | 唐伯虎点秋香 | 喜剧、古装、爱情 | 喜剧、古装 |
4 问题:hobbies 中每个字符串的长度是未知的,因此我们如何判断要截取几次?我们应该正向截取还是反向截取?
以 id=1 为例:
(1)经过分析可知,反向截取会更容易。
第一次:substring_index('动画','、',-1) --- 得到:动画
第二次:substring_index('动画、剧情','、',-1) --- 得到:剧情
第三次:substring_index('动画、剧情、奇幻','、',-1) --- 得到:奇幻
结束分割。
(2)若想实现上述步骤,需要动态的自动改变字段hobbies的值,将本次得到的数据给截取掉。问题:① 如何动态截取hobbies。② 截取到什么时候结束。
5 解决:
问题一:仍然利用string_index 函数进行截取
substring_index(hobbies, '、', 1) --- '动画'
substring_index(hobbies, '、', 2) --- '动画、剧情'
substring_index(hobbies, '、', 3) --- '动画、剧情、奇幻'
第一次:substring_index(substring_index(hobbies, '、', 1), '、', -1) --- 得到:动画
第二次:substring_index(substring_index(hobbies, '、', 2), '、' ,-1) --- 得到:剧情
第三次:substring_index(substring_index(hobbies, '、', 3), '、' ,-1) --- 得到:奇幻
这里的1、2、3 可以换成临时表(tmp)中的自增id 即: substring_index(substring_index(hobbies, '、', id), '、' ,-1)。
问题二:截取多少次为止?
(1)我们可以看到有几个分隔符,就截取 分隔符数+1次。比如:'动画、剧情、奇幻' 有 2 个分隔符,根据上述描述可以看出需要分割3次。同理 '剧情、爱情' ,有 1 个分隔符,但是需要分割2次。
(2)因此需要截取多少次为止的问题,就转化为了求字符串中有几个分隔符的问题。
(3)解决:利用原始字符串的长度 - 除去分隔符的字符串的长度 = 所有分隔符的长度 = 分隔符个数 * 分隔符所占字节【LENGTH(hobbies)-LENGTH(REPLACE(hobbies, '、', ''))】。注意:中文分隔符占两个字节,因此一般我们可以现将分隔符转为英文字符,之后在进行计算,这样直接得到分隔符个数。即:LENGTH(REPLACE(hobbies, '、', ','))-LENGTH(REPLACE(hobbies, '、', '')) = n。
(4)因此每一行拆分的结束条件:temp.id <LENGTH(hobbies)-LENGTH(REPLACE(hobbies, '、', ''))
6 代码
SELECT
m.id,m.name,m.hobbies,
SUBSTRING_INDEX(SUBSTRING_INDEX(m.hobbies,'、',b.help_topic_id+1),'、',-1) as tmp
FROM `movies`m
inner join mysql.help_topic b
on b.help_topic_id<LENGTH(REPLACE(m.hobbies,'、',',')) -LENGTH(REPLACE(m.hobbies,'、','')) +1
这里用的临时表是mysql 自带的help_topic表。由于该表 id 是从 0 开始的,因此在进行判断时要 +1。
注意:当我们系统上线后,可能由于权限或者其他问题导致我们不能访问 mysql 中自带的表。因此为了保险起见,可以自己创建一个临时表。 (只要保证其中一个字段是int类型,且连续自增即可)
到此这篇关于sql拆分字符串实现一行变多行的实例代码的文章就介绍到这了,更多相关sql拆分字符串内容请搜索编程客栈(www.lsjlt.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网(www.lsjlt.com)!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
sql拆分字符串实现一行变多行的实例代码
下载Word文档到电脑,方便收藏和打印~
猜你喜欢
sql拆分字符串实现一行变多行的实例代码
如何用SQL实现字段拆分成多行
Python中拆分具有多个分隔符的字符串方法实例
python字符串的多行输出的实例详解
Oracle中分割字符串的方法实例代码
C语言实现字符串替换的示例代码怎么写
R语言怎么实现提取包含某字符串的行变量
编程热搜
[mysql]mysql8修改root密码
use mysqlselect * from user where user="root";update user set password=password("mysql@2020") where user="root";ERROR 1064 (42000)MySQL专题3之MySQL管理
1、启动以及关闭MySQL服务器- 首先,我们需要通过以下命令来检查MySQL服务器是否已经启动:ps -ef | grep mysqld- 如果MySQL已经启动,以上命令将输出mysql进程列表,如果mysql未启动,你可以使用以下
编程资源站
- 资料下载
- 历年试题
目录
留言反馈