mysql rownumer实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 | -- 窗口行数 select e.* ,row_number() over(partition by deptno order by empno) as ROW_NUMBER from emp e; -- SQL SELECT E.*, IF(@DEPTNO = DEPTNO, @RN := @RN + 1, @RN := 1) AS ROW_NUMBER, @DEPTNO := DEPTNO AS VAR1 FROM EMP E, ( SELECT @DEPTNO := '' , @RN := 0) C ORDER BY DEPTNO; -- 窗口函数 求每个人员占他所在部门总工资的百分比 SELECT E.*, TRUNC(SAL / SUM (SAL) OVER(PARTITION BY DEPTNO), 3) AS SALPERCENT FROM EMP E ORDER BY DEPTNO; SELECT E.*, SAL / ( SELECT SUMOVER FROM ( SELECT DEPTNO, SUM (SAL) AS SUMOVER FROM emp E1 GROUP BY DEPTNO) X WHERE X.DEPTNO = E.DEPTNO) AS SalPercent FROM emp E ORDER BY DEPTNO; 拿部门第二的工资的人 SELECT * FROM ( SELECT E.*, ROW_NUMBER() OVER(PARTITION BY DEPTNO ORDER BY SAL DESC ) AS RN FROM EMP E) WHERE RN = 2; SELECT * FROM ( SELECT E.*, IF(@DEPTNO = DEPTNO, @RN := @RN + 1, @RN := 1) AS RN, @DEPTNO := DEPTNO FROM EMP E, ( SELECT @RN := 0, @DEPTNO := 0) C ORDER BY DEPTNO, SAL DESC ) X WHERE X.RN = 2; dense_rank()函数 SELECT empno, ename, sal, deptno, rank() OVER(PARTITION BY deptno ORDER BY sal desc ) as rank, dense_rank() OVER(PARTITION BY deptno ORDER BY sal desc ) as dense_rank FROM emp e; select empno,ename,sal,deptno, if(@deptno = deptno,if(@sal=sal,@rn:=@rn,@rn3:=@rn3+1),@rn:=1) as "RANK() OVER" , if(@sal =sal,@rn2:=@rn2 ,if(@deptno = deptno,@rn2:=@rn2+1,@rn2:=1)) as "DENSE_RANK() OVER" , if(@deptno = deptno,@rn:=@rn+1,@rn:=1) as "ROW_NUMBER() OVER" , @deptno:=deptno,@sal:=sal from ( select empno,ename,sal,deptno from emp a ,( select @rn:=1,@deptno:=0,@rn2:=0,@rn3:=0,@sal:=0,@i:=0) b order by deptno,sal desc ) c; 连续获得冠军的有哪些 create table nba as SELECT '公牛' AS TEAM, '1991' AS Y FROM DUAL UNION ALL SELECT '公牛' AS TEAM, '1992' AS Y FROM DUAL UNION ALL SELECT '公牛' AS TEAM, '1993' AS Y FROM DUAL UNION ALL SELECT '活塞' AS TEAM, '1990' AS Y FROM DUAL UNION ALL SELECT '火箭' AS TEAM, '1994' AS Y FROM DUAL UNION ALL SELECT '火箭' AS TEAM, '1995' AS Y FROM DUAL UNION ALL SELECT '公牛' AS TEAM, '1996' AS Y FROM DUAL UNION ALL SELECT '公牛' AS TEAM, '1997' AS Y FROM DUAL UNION ALL SELECT '公牛' AS TEAM, '1998' AS Y FROM DUAL UNION ALL SELECT '马刺' AS TEAM, '1999' AS Y FROM DUAL UNION ALL SELECT '湖人' AS TEAM, '2000' AS Y FROM DUAL UNION ALL SELECT '湖人' AS TEAM, '2001' AS Y FROM DUAL UNION ALL SELECT '湖人' AS TEAM, '2002' AS Y FROM DUAL UNION ALL SELECT '马刺' AS TEAM, '2003' AS Y FROM DUAL UNION ALL SELECT '活塞' AS TEAM, '2004' AS Y FROM DUAL UNION ALL SELECT '马刺' AS TEAM, '2005' AS Y FROM DUAL UNION ALL SELECT '热火' AS TEAM, '2006' AS Y FROM DUAL UNION ALL SELECT '马刺' AS TEAM, '2007' AS Y FROM DUAL UNION ALL SELECT '凯尔特人' AS TEAM, '2008' AS Y FROM DUAL UNION ALL SELECT '湖人' AS TEAM, '2009' AS Y FROM DUAL UNION ALL SELECT '湖人' AS TEAM, '2010' AS Y FROM DUAL; --Oracle SELECT TEAM, MIN (Y), MAX (Y) FROM ( SELECT E.*, ROWNUM, ROW_NUMBER() OVER(PARTITION BY TEAM ORDER BY Y) AS RN, ROWNUM - ROW_NUMBER() OVER(PARTITION BY TEAM ORDER BY Y) AS DIFF FROM NBA E ORDER BY Y) GROUP BY TEAM, DIFF HAVING MIN (Y) != MAX (Y) ORDER BY 2; -- MySQL SELECT TEAM, MIN (Y), MAX (Y) FROM ( SELECT TEAM, Y, IF(@TEAM = TEAM, @RN := @RN + 1, @RN := 1) AS RWN, @RN1 := @RN1 + 1 AS RN, @TEAM := TEAM FROM nba N, ( SELECT @RN := 0, @TEAM := '' , @RN1 := '' ) C) A GROUP BY RN - RWN HAVING MIN (Y) != MAX (Y) |
螃蟹在剥我的壳,笔记本在写我,漫天的我落在枫叶上雪花上,而你在想我。
--章怀柔
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?