如何用SQL实现字段拆分成多行
这篇文章给大家介绍如何用SQL实现字段拆分成多行,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
把表中某字段根据分隔符拆分成N个字符串后,再用这N个字符串把这一行演变成N行。
用SQL来解决这个问题非常烦琐!
SQL里没有提供集合对象,不能提供根据拆分后的字符串集合把一行变成多行的操作。解决这个问题的思路就是先求出字段拆分后的最大字符串个数M,然后构造一个M行1列的临时表T2,其列名为lv,则各行lv值分别为1,2,……,M,然后用原表与之叉乘,叉乘时取字段拆分后的第T2.lv个字符串。这样写出来的SQL是多个子查询嵌套而成,其语法是比较复杂的。而且各种数据库中拆分字符串的函数并不统一,所以SQL的写法也各不相同。
举个例子:现有学生选修课数据表COURSES数据如下,要求查出每个学生选修了几门课:
COURSE | STUDENTS |
Chinese | Tom,Kate,John,Jimmy |
Russia | Tom,Cart,Jimmy |
Spanish | Kate,Joan,Cart |
Portuguese | John,Tom |
History | Tom,Cart,Kate |
Music | Kate,Joan,Tom |
要求输出结果如下:
STUDENT | NUM |
Tom | 5 |
Kate | 4 |
Cart | 3 |
Jimmy | 2 |
Joan | 2 |
John | 2 |
以Oracle为例,用SQL写出来是这样:
SELECT STUDENT, COUNT(*) NUM FROM
(SELECT T1.COURSE, REGEXP_SUBSTR(T1.STUDENTS, '[^,]+', 1, T2.LV ) STUDENT
FROM COURSES T1,
( SELECT LEVEL LV
FROM (SELECT MAX(REGEXP_COUNT(A.STUDENTS, '[^,]+', 1)) R_COUNT
FROM COURSES A
) B
CONNECT BY LEVEL <= B.R_COUNT) T2
WHERE REGEXP_SUBSTR(T1.STUDENTS, '[^,]+', 1, T2.LV) IS NOT NULL
) C
GROUP BY STUDENT
ORDER BY NUM DESC;
这里的C就是前文提到的那个临时表,可见这个SQL层次很多,可读性比较差,不易读懂。
如果用集算器的SPL语言来解决这个问题,就会简单很多,只需1行代码:
connect("mydb").query("SELECT * FROM COURSES").news(STUDENTS.split@c();~:STUDENT).groups(STUDENT;count(1):NUM).sort(-NUM)
SPL语言有集合对象,并提供了根据集合把一行扩展成多行的功能,所以写起来思路清晰明了,简便易懂,并且语法统一,不论数据来自哪种数据库还是来自文件型数据源,写法都是一样的。
关于如何用SQL实现字段拆分成多行就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341