与oracle的 rownumber() over(partition by xxx  order by xxx )语句类似,即:对表分组后排序

创建测试emp表

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
DROP TABLE IF EXISTS emp;
CREATE TABLE emp (
  empno decimal(4,0) NOT NULL,
  ename varchar(10) DEFAULT NULL,
  job varchar(9) DEFAULT NULL,
  mgr decimal(4,0) DEFAULT NULL,
  hiredate datetime DEFAULT NULL,
  sal decimal(7,2) DEFAULT NULL,
  comm decimal(7,2) DEFAULT NULL,
  deptno decimal(2,0) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
 
-- ----------------------------
-- Records of emp
-- ----------------------------
INSERT INTO emp VALUES ('7369''SMITH''CLERK''7902''1980-12-17 00:00:00''800.00'null'20');
INSERT INTO emp VALUES ('7499''ALLEN''SALESMAN''7698''1981-02-20 00:00:00''1600.00''300.00''30');
INSERT INTO emp VALUES ('7521''WARD''SALESMAN''7698''1981-02-22 00:00:00''1250.00''500.00''30');
INSERT INTO emp VALUES ('7566''JONES''MANAGER''7839''1981-04-02 00:00:00''2975.00'null'20');
INSERT INTO emp VALUES ('7654''MARTIN''SALESMAN''7698''1981-09-28 00:00:00''1250.00''1400.00''30');
INSERT INTO emp VALUES ('7698''BLAKE''MANAGER''7839''1981-05-01 00:00:00''2850.00'null'30');
INSERT INTO emp VALUES ('7782''CLARK''MANAGER''7839''1981-06-09 00:00:00''2450.00'null'10');
INSERT INTO emp VALUES ('7788''SCOTT''ANALYST''7566''1982-12-09 00:00:00''3000.00'null'20');
INSERT INTO emp VALUES ('7839''KING''PRESIDENT'null'1981-11-17 00:00:00''5000.00'null'10');
INSERT INTO emp VALUES ('7844''TURNER''SALESMAN''7698''1981-09-08 00:00:00''1500.00''0.00''30');
INSERT INTO emp VALUES ('7876''ADAMS''CLERK''7788''1983-01-12 00:00:00''1100.00'null'20');
INSERT INTO emp VALUES ('7900''JAMES''CLERK''7698''1981-12-03 00:00:00''950.00'null'30');
INSERT INTO emp VALUES ('7902''FORD''ANALYST''7566''1981-12-03 00:00:00''3000.00'null'20');
INSERT INTO emp VALUES ('7934''MILLER''CLERK''7782''1982-01-23 00:00:00''1300.00'null'10');

需求:按部门分组后显示工资为前三的员工信息

SQL:

1
select from emp as where 3> (select count(*) from emp where deptno = a.deptno and sal < a.sal  )  order by a.deptno ,a.sal

  

解析SQL:

3>...

目的是获取前三条数据,可以多次修改

emp where deptno = a.deptno

目的是确定分组字段

sal < a.sal

排序条件

结果图:

zhuanzi https://www.cnblogs.com/duyunchao-2261/p/7460294.html

MySQL 分组后取每组前N条数据的更多相关文章

  1. SQL分组排序后取每组最新一条数据的另一种思路

    在hibernate框架和mysql.oracle两种数据库兼容的项目中实现查询每个id最新更新的一条数据. 之前工作中一直用的mybatis+oracle数据库这种,一般写这类分组排序取每组最新一条 ...

  2. 记一次有意思的 SQL 实现 → 分组后取每组的第一条记录

    开心一刻 今天,朋友气冲冲的走到我面前 朋友:我不是谈了个女朋友,谈了三个月嘛,昨天我偷看她手机,你猜她给我备注什么 我:备注什么? 朋友:舔狗 2 号! 我一听,气就上来了,说道:走,找她去,这婆娘 ...

  3. mysql 分组后取每个组内最新的一条数据

    首先,将按条件查询并排序的结果查询出来. mysql order by accepttime desc; +---------------------+------+-----+ | acceptti ...

  4. mysql单列去重复group by分组取每组前几条记录加order by排序

    mysql分组取每组前几条记录(排名) 附group by与order by的研究,需要的朋友可以参考下 --按某一字段分组取最大(小)值所在行的数据 复制代码代码如下: /* 数据如下: name ...

  5. MSSQL 分组后取每组第一条(group by order by)

    查询中经常遇到这种查询,分组后取每组第一条.分享下一个SQL语句: --根据 x 分组后.根据 y 排序后取第一条 select * from ( select ROW_NUMBER() over(p ...

  6. SQL获取分组后取某字段最大一条记录(求每个类别中最大的值的列表)

    获取分组后取某字段最大一条记录 方法一:(效率最高) select * from test as a where typeindex = (select max(b.typeindex) from t ...

  7. oracle分组后取某组中最大的值

    查询username,根据fundcode分组,按照date倒序,取date最大的一条数据 select * from ( select username, row_number() over(par ...

  8. Oracle分组后取某列最大值的行数据

    select * from ( select last_comment, row_number() over(partition by employeeid,roadline,stationname ...

  9. Mysql SQL分组取每组前几条记录

    按name分组取最大的两个val: [比当前记录val大的条数]小于2条:即当前记录为为分组中的前两条 > (select count(*) from tb where name = a.nam ...

随机推荐

  1. mysql中使用正则表达式查询

    正则表达式功能确实很强大,那天专门抽空学学,这里就暂时在mysql查询中用用. 正则表达式强大而灵活,可以应用于非常复杂的查询. 选项 说明(自动加匹配二字) 例子 匹配值示例 ^ 文本开始字符 '^ ...

  2. nand ECC 算法记录

    nandflash ECC 原理记录. nand ECC 全称是Error Checking and correction. 该算法分为列校验和行校验. 列校验有下图所示: * 如上图所示, CP0 ...

  3. AM335x移植linux内核_转

    AM335x移植linux内核 该博客中详细介绍了移植linux内核到AM335x上相关,设备驱动采用设备树(DT)方式加载,包含设备启动.uboot.kernel.driver.rootfs及简单上 ...

  4. git不能上传空目录和设备文件

    git不能上传空目录和设备文件:目录和设备文件不能完成校验. 使用命令校验: sha1sum  console

  5. VMware网络连接失败

    假如你碰到了VMware 网络被断开, 明明已经分配了适配器, 客户端却显示网络断开没有连接. 可用恢复默认的方法重置所有网卡及服务. 进主工具首页.点击: 虚拟网络编辑器,然后点击下面的恢复默认. ...

  6. JVM 详谈

    JVM 详谈 本来这次应该讲讲ORM 的几个框架,但是笔者还没有完全总结出来,所以这里先插入一次学习JVM的心得.作为一个Java程序员,如果不了解JVM的工作原理,就很难从底层去把 握Java语言和 ...

  7. Game publishing request was abnormally terminated (ID 27492).

    本地可以正常发布:远程发布报错.怀疑跟直接删除数据库记录有关,wp_myarcadegames/wp_posts Game publishing request was abnormally term ...

  8. [mysql] 关联查询sql记录

    //查询账单关联订单 select o.id as id, o.order_no as orderNo, o.case_no as caseNo, o.send_time as sendTime, o ...

  9. 关于用Cocos2d-x.3.10运行别人游戏项目的步骤

    1.首先打开Cocos那个一体化软件. 2.创建工程,取名字,选择路径. 3.用VS2013打开新建的项目. 4.打开cocosdata(我自己放游戏项目的文件目录)的相应项目(自己刚创建的). 5. ...

  10. 在caffe中增加和convolution相同的层

    1.打开vision_layers.hpp,复制ConvolutionLayer的代码,把类名还有构造函数的名字改为WtfLayer,把里面的带GPU的函数删掉. 2.Wtf_layer.cpp 添加 ...