今天给大家介绍一下SQL怎么查询每个分组都出现的字段值。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。
数据分组以后,要找出在每个分组中都出现的某个字段值。
用SQL来解决这个问题并不容易!
SQL缺少单纯的分组操作,只能返回各分组的统计值,而不能对各组的成员再进行更细的交、差、并等集合运算。要解决这种问题就需要多层嵌套子查询来变相地实现。
举个例子:查询每周都加班的员工以进行表彰。现有加班数据表OVERTIME_WORK数据如下:
WORKDATE | NAME |
2019-07-01 | Tom |
2019-07-02 | John |
2019-07-03 | Tom |
2019-07-04 | Cart |
2019-07-08 | Tom |
2019-07-09 | Jordan |
2019-07-10 | Kate |
2019-07-10 | John |
2019-07-15 | Leon |
2019-07-16 | John |
2019-07-17 | Tom |
2019-07-18 | John |
2019-07-22 | Jim |
2019-07-23 | Tom |
2019-07-24 | John |
2019-07-25 | Cart |
… | … |
以Oracle为例,用SQL写出来是这样:
WITH A AS
(SELECT COUNT(*) NUM FROM
(SELECT DISTINCT TO_CHAR(WORKDATE,'IW') FROM OVERTIME_WORK )
),
B AS
(SELECT TO_CHAR(WORKDATE,'IW') W, NAME
FROM OVERTIME_WORK
GROUP BY TO_CHAR(WORKDATE,'IW'), NAME
),
C AS
(SELECT NAME, COUNT(*) NUM FROM B GROUP BY NAME )
SELECT NAME FROM C WHERE NUM=(SELECT NUM FROM A);
这里的A查出共有几周,B查出每周加班的不同员工,C查出B里各员工的出现次数,最后从C里选出出现次数与总周数相等的员工。解决思路比较绕,这种SQL既难写又难懂。
集算器的SPL语言支持集合运算,解决这个问题就会简单很多,计算出每周加班员工的交集即可,只需1行代码:
connect("mydb").query("SELECT * FROM OVERTIME_WORK").group((WORKDATE-date("2019-07-01"))\7).(~.(NAME)).isect()
以上就是SQL怎么查询每个分组都出现的字段值的全部内容了,更多与SQL怎么查询每个分组都出现的字段值相关的内容可以搜索编程网之前的文章或者浏览下面的文章进行学习哈!相信小编会给大家增添更多知识,希望大家能够支持一下编程网!