postgresql sum max min

创建表

create table(empno smallint, ename varchar(20), job varchar(20), mgr smallint, hiredate date, sal bigint, comm bigint, deptno smallint);

insert into jinbo.employee(empno,ename,job, mgr, hiredate, sal, comm, deptno) values (7499, 'ALLEN', 'SALEMAN', 7698, '2014-11-12', 16000, 300, 30);

insert into jinbo.employee(empno,ename,job, mgr, hiredate, sal, comm, deptno) values (7499, 'ALLEN', 'SALEMAN', 7698, '2014-11-12', 16000, 300, 30);

insert into jinbo.employee(empno,ename,job, mgr, hiredate, sal, comm, deptno) values (7654, 'MARTIN', 'SALEMAN', 7698, '2016-09-12', 12000, 1400, 30);

select * from jinbo.employee;
 empno | ename  |   job   | mgr  |  hiredate  |  sal  | comm | deptno 
-------+--------+---------+------+------------+-------+------+--------
  7499 | ALLEN  | SALEMAN | 7698 | 2014-11-12 | 16000 |  300 |     30
  7566 | JONES  | MANAGER | 7839 | 2015-12-12 | 32000 |    0 |     20
  7654 | MARTIN | SALEMAN | 7698 | 2016-09-12 | 12000 | 1400 |     30
(3 rows)

查询所有员工信息

# select * from jinbo.employee;
 empno | ename  |   job   | mgr  |  hiredate  |  sal  | comm | deptno 
-------+--------+---------+------+------------+-------+------+--------
  7499 | ALLEN  | SALEMAN | 7698 | 2014-11-12 | 16000 |  300 |     30
  7566 | JONES  | MANAGER | 7839 | 2015-12-12 | 32000 |    0 |     20
  7654 | MARTIN | SALEMAN | 7698 | 2016-09-12 | 12000 | 1400 |     30
(3 rows)

查询每个部门的最高薪与最低薪

# select deptno, max(sal), min(sal) from jinbo.employee group by deptno;
 deptno |  max  |  min  
--------+-------+-------
     30 | 16000 | 12000
     20 | 32000 | 32000

查询每个部门的总薪资

# select deptno, sum(sal) from jinbo.employee  group by deptno;
 deptno |  sum  
--------+-------
     30 | 28000
     20 | 32000

查询 按从高到低顺序同组下一名的薪资

(不为拉仇恨,只为引斗志)

# select deptno, sal, lead(sal, 1) over w, lag(sal, 1) over w from jinbo.employee window w as (partition by deptno order by sal desc) order by deptno, sal desc;
 deptno |  sal  | lead  |  lag  
--------+-------+-------+-------
     20 | 32000 |       |      
     30 | 16000 | 12000 |      
     30 | 12000 |       | 16000
(3 rows)

#等同于

# select deptno, sal, lead(sal, 1) over (partition by deptno order by sal desc), lag(sal, 1) over (partition by deptno order by sal desc) from jinbo.employee order by deptno, sal desc;
 deptno |  sal  | lead  |  lag  
--------+-------+-------+-------
     20 | 32000 |       |      
     30 | 16000 | 12000 |      
     30 | 12000 |       | 16000
(3 rows)

发布了236 篇原创文章 · 获赞 145 · 访问量 44万+

猜你喜欢

转载自blog.csdn.net/u011944141/article/details/91448863