首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >查找min(sal)和员工名称SQL

查找min(sal)和员工名称SQL
EN

Stack Overflow用户
提问于 2016-04-05 11:09:15
回答 3查看 66关注 0票数 0

我有一张名叫emp的桌子,我想找一位薪水最低的办事员.我的代码select min(sal) as min from emp where job='CLERK';工作得很好,我得到了以下信息:

代码语言:javascript
复制
  MIN
----------
       800

但是我也想显示一下职员的名字,那就是Smith。当我运行这个代码select ename, min(sal) as min from emp where job='CLERK' group by name;时,它会给我表中所有的办事员,这并不是我真正想要的。这是我桌子上的一个片段:

代码语言:javascript
复制
CREATE TABLE EMP
       (EMPNO NUMBER(4) NOT NULL,
        ENAME VARCHAR2(10),
        JOB VARCHAR2(9),
        MGR NUMBER(4),
        HIREDATE DATE,
        SAL NUMBER(7, 2),
        COMM NUMBER(7, 2),
        DEPTNO NUMBER(2));
INSERT INTO EMP VALUES
        (7369, 'SMITH',  'CLERK',     7902,
        TO_DATE('17-DEC-1980', 'DD-MON-YYYY'),  800, NULL, 20);
INSERT INTO EMP VALUES
        (7499, 'ALLEN',  'SALESMAN',  7698,
        TO_DATE('20-FEB-1981', 'DD-MON-YYYY'), 1600,  300, 30);
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2016-04-05 11:48:54

尝尝这个

代码语言:javascript
复制
SELECT * FROM emp 
WHERE SAL = (select MIN(SAL) sal from emp WHERE JOB ='CLERK')
and JOB ='CLERK';
票数 1
EN

Stack Overflow用户

发布于 2016-04-05 11:11:36

您可以使用row_number

代码语言:javascript
复制
select ename, sal as min
from (
  select ename, sal,
         row_number() over (order by sal) as rn  
  from emp 
  where job='CLERK' ) t
where t.rn = 1
票数 0
EN

Stack Overflow用户

发布于 2016-04-05 11:12:29

您可以使用子查询和排序函数来完成这一任务:

代码语言:javascript
复制
select e.*
from (select e.*,
             dense_rank() over (partition by job order by salary) as seqnum
      from emp
      where job = 'CLERK' 
     ) e
where seqnum = 1;

如果有领带,这将返回多个行。如果您只需要一个,则可以使用row_number()而不是dense_rank()

而且,如果要将所有办事员的名称作为单个分隔值,则可以使用list_agg()

代码语言:javascript
复制
select listagg(e.name, ', ') within group (order by e.name) as names
from (select e.*,
             dense_rank() over (partition by job order by salary) as seqnum
      from emp
      where job = 'CLERK' 
     ) e
where seqnum = 1;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36424716

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档