温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

SQL怎么查询每个分组都出现的字段值

发布时间:2022-01-15 15:45:04 来源:亿速云 阅读:324 作者:柒染 栏目:互联网科技

今天给大家介绍一下SQL怎么查询每个分组都出现的字段值。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。

数据分组以后,要找出在每个分组中都出现的某个字段值。

用SQL来解决这个问题并不容易!

SQL缺少单纯的分组操作,只能返回各分组的统计值,而不能对各组的成员再进行更细的交、差、并等集合运算。要解决这种问题就需要多层嵌套子查询来变相地实现。

举个例子:查询每周都加班的员工以进行表彰。现有加班数据表OVERTIME_WORK数据如下:

WORKDATENAME
2019-07-01Tom
2019-07-02John
2019-07-03Tom
2019-07-04Cart
2019-07-08Tom
2019-07-09Jordan
2019-07-10Kate
2019-07-10John
2019-07-15Leon
2019-07-16John
2019-07-17Tom
2019-07-18John
2019-07-22Jim
2019-07-23Tom
2019-07-24John
2019-07-25Cart

以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怎么查询每个分组都出现的字段值相关的内容可以搜索亿速云之前的文章或者浏览下面的文章进行学习哈!相信小编会给大家增添更多知识,希望大家能够支持一下亿速云!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sql
AI