MySQL 抑制结果集中的重复值
2021-01-28 本文已影响0人
只是甲
备注:测试数据库版本为MySQL 8.0
如需要scott用户下建表及录入数据语句,可参考:
scott建表及录入数据sql脚本
一.需求
生成报表时如果两行的同一列包含相同值,希望这个值仅显示一次。
例如,要从表emp中找出deptno和ename,按deptno给所有行分组,而且deptno仅显示一次。
希望返回如下结果集:
+--------+--------+
| deptno | ename |
+--------+--------+
| 10 | CLARK |
| NULL | KING |
| NULL | MILLER |
| 20 | SMITH |
| NULL | JONES |
| NULL | SCOTT |
| NULL | ADAMS |
| NULL | FORD |
| 30 | ALLEN |
| NULL | WARD |
| NULL | MARTIN |
| NULL | BLAKE |
| NULL | TURNER |
| NULL | JAMES |
+--------+--------+
二.解决方案
这是非常简单的格式设置问题,使用MySQl提供的窗口函数LAG OVER能够很容易解决这个问题。
select case when lag(deptno) over w = deptno then null else deptno end as deptno,
ename
from emp
window w as (order by deptno);
测试记录:
mysql> select case when lag(deptno) over w = deptno then null else deptno end as deptno,
-> ename
-> from emp
-> window w as (order by deptno);
+--------+--------+
| deptno | ename |
+--------+--------+
| 10 | CLARK |
| NULL | KING |
| NULL | MILLER |
| 20 | SMITH |
| NULL | JONES |
| NULL | SCOTT |
| NULL | ADAMS |
| NULL | FORD |
| 30 | ALLEN |
| NULL | WARD |
| NULL | MARTIN |
| NULL | BLAKE |
| NULL | TURNER |
| NULL | JAMES |
+--------+--------+
14 rows in set (0.00 sec)