zoukankan      html  css  js  c++  java
  • SQL 语句-partition by

    /******  ******/
    初始化数据
    
    create table employee (empid int ,deptid int ,salary decimal(10,2))
    insert into employee values(1,10,5500.00)
    insert into employee values(2,10,4500.00)
    insert into employee values(3,20,1900.00)
    insert into employee values(4,20,4800.00)
    insert into employee values(5,40,6500.00)
    insert into employee values(6,40,14500.00)
    insert into employee values(7,40,44500.00)
    insert into employee values(8,50,6500.00)
    insert into employee values(9,50,7500.00)
    

    数据显示为

    empid       deptid      salary
    ----------- ----------- ---------------------------------------
    1           10          5500.00
    2           10          4500.00
    3           20          1900.00
    4           20          4800.00
    5           40          6500.00
    6           40          14500.00
    7           40          44500.00
    8           50          6500.00
    9           50          7500.00
    

    需求:根据部门分组,显示每个部门的工资等级

    SQL脚本:

    SELECT *, Row_Number() OVER (partition by deptid ORDER BY salary desc) rank 
    FROM employee
    
    empid       deptid      salary                                  rank
    ----------- ----------- --------------------------------------- --------------------
    1           10          5500.00                                 1
    2           10          4500.00                                 2
    4           20          4800.00                                 1
    3           20          1900.00                                 2
    7           40          44500.00                               1
    6           40          14500.00                               2
    5           40          6500.00                                 3
    9           50          7500.00                                 1
    8           50          6500.00                                 2
    

    SQL脚本:

    SELECT *
    FROM
    	(SELECT *, Row_Number() OVER (partition by deptid ORDER BY salary desc) R
    	 FROM employee) B
    WHERE B.R =1
    
    #只显示部门工资最高的
    /******  ******/
    
     select *
      from (
      select name,学科,成绩,ROW_NUMBER() over (PARTITION by 学科 order by 成绩 desc) as num
      from [XSBOOK].[dbo].[XKCJ]) T
      where T.num <= 3 order by T.学科
      
    name       学科         成绩          num
    ---------- ---------- ----------- --------------------
    李四         数学         98          1
    李四         数学         95          2
    张三         数学         93          3
    张三         英语         92          1
    张三         英语         92          2
    李四         英语         90          3
    李四         语文         85          1
    李四         语文         81          2
    张三         语文         80          3
    

    语法形式,ROW_NUMBER() OVER(PARTITION BY COL1 ORDER BY COL2)
    解释:根据COL1分组,在分组内部根据 COL2排序,而此函数计算的值就表示每组内部排序后的顺序编号(组内连续的唯一的)

  • 相关阅读:
    ASP.NET MVC 扩展相关
    新.NET开发十大必备工具
    c#调用存储过程两种方法
    TweakUI取消pc喇叭声
    baidu mp3竟然还加密,太扯了
    NTLM在使用代理服务器的情况下,第三次握手可能出错
    httpclient解析gzip网页
    eclipse不能自动编译工程的解决方法
    bat设置环境变量
    java的ZipOutputStream压缩文件的两个问题(乱码和每次zip后文件md5变化)
  • 原文地址:https://www.cnblogs.com/li-volleyball/p/5481864.html
Copyright © 2011-2022 走看看