许可优化
产品
解决方案
服务支持
关于
软件库
当前位置:服务支持 >  软件文章 >  MySQL:去除结果集中的重复值

MySQL:去除结果集中的重复值

阅读数 1352
点赞 79
article_banner

备注:测试数据库版本为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)


武汉格发信息技术有限公司,格发许可优化管理系统可以帮你评估贵公司软件许可的真实需求,再低成本合规性管理软件许可,帮助贵司提高软件投资回报率,为软件采购、使用提供科学决策依据。支持的软件有: CAD,CAE,PDM,PLM,Catia,Ugnx, AutoCAD, Pro/E, Solidworks ,Hyperworks, Protel,CAXA,OpenWorks LandMark,MATLAB,Enovia,Winchill,TeamCenter,MathCAD,Ansys, Abaqus,ls-dyna, Fluent, MSC,Bentley,License,UG,ug,catia,Dassault Systèmes,AutoDesk,Altair,autocad,PTC,SolidWorks,Ansys,Siemens PLM Software,Paradigm,Mathworks,Borland,AVEVA,ESRI,hP,Solibri,Progman,Leica,Cadence,IBM,SIMULIA,Citrix,Sybase,Schlumberger,MSC Products...

相关文章
QR Code
微信扫一扫,欢迎咨询~

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 155-2731-8020
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

手机不正确

公司不为空