SQLに関する質問です。初歩的なことだと思うのですが、ご教授お願いします。
下のテーブルから、MGR(マネージャーの番号)、人数、最高給料、最低給料、
マネージャーの名前を抽出したいです。
MGR(マネージャーの番号)、人数、最高給料、最低給料に関しては
SELECT MGR AS マネージャー, COUNT(MGR) AS 人数, MAX(SAL) AS 最高給料,
MIN(SAL) AS 最低給料
FROM EMP
WHERE MGR IS NOT NULL
GROUP BY MGR
ORDER BY MGR ASC
で出すことはできましたが、マネージャーの名前の表示の仕方がわかりません。
上記のSELECT部分に「ENAME」を加えると”GROUP BYの式ではありません”
と表示されてしまいます。マネージャーの番号に対応した、ENAMEの表示をしたいです。
[テーブルEMP]
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
7379 SMITH CLERK 7902 1980-12-17 00:00:00 400 <NULL> 10
7499 ALLEN SALESMAN 7698 1981-02-20 00:00:00 400 300 30
7521 WARD SALESMAN 7698 1981-02-22 00:00:00 1250 500 30
7566 JONES MANAGER 7839 1981-04-02 00:00:00 2975 <NULL> 20
7654 MARTIN SALESMAN 7698 1981-09-28 00:00:00 1250 1400 30
7698 BLAKE MANAGER 7839 1981-05-01 00:00:00 2580 <NULL> 30
7782 CLARK MANAGER 7839 1981-06-09 00:00:00 2450 <NULL> 10
7788 SCOTT ANALYST 7566 1987-04-19 00:00:00 3000 <NULL> 20
7839 KING PRESIDENT <NULL> 1981-11-17 00:00:00 5000 <NULL> <NULL>
7844 TURNER SALESMAN 7698 1981-09-08 00:00:00 1500 0 30
7876 ADAMS CLERK 7788 1987-05-23 00:00:00 1100 <NULL> 20
7900 JAMES CLERK 7698 1981-12-03 00:00:00 950 <NULL> 30
7902 FORD ANALYST 7566 1981-12-03 00:00:00 3000 <NULL> 20
7934 MILLER CLERK 7782 1982-01-23 00:00:00 1300 <NULL> 10
[CLEATE TABLE EMP とINSERT INTO EMP]
CREATE TABLE EMP
(EMPNO NUMBER(4) PRIMARY KEY NOT NULL, ENAME VARCHAR2(10) NOT NULL, JOB
VARCHAR2(9), MGR NUMBER(4), HIREDATE DATE, SAL NUMBER(8), COMM
NUMBER(8), DEPTNO NUMBER(2));
INSERT INTO EMP VALUES (7379, 'SMITH', 'CLERK', 7902,
TO_DATE('1980-12-17', 'yyyy/mm/dd'), 400, NULL , 10);
INSERT INTO EMP VALUES (7499, 'ALLEN', 'SALESMAN', 7698,
TO_DATE('1981-2-20', 'yyyy/mm/dd'), 400, 300 , 30);
INSERT INTO EMP VALUES (7521, 'WARD', 'SALESMAN', 7698,
TO_DATE('1981-2-22', 'yyyy/mm/dd'), 1250, 500 , 30);
INSERT INTO EMP VALUES (7566, 'JONES', 'MANAGER', 7839,
TO_DATE('1981-4-2', 'yyyy/mm/dd'), 2975, NULL , 20);
INSERT INTO EMP VALUES (7654, 'MARTIN', 'SALESMAN', 7698,
TO_DATE('1981-9-28', 'yyyy/mm/dd'), 1250, 1400 , 30);
INSERT INTO EMP VALUES (7698, 'BLAKE', 'MANAGER', 7839,
TO_DATE('1981-5-1', 'yyyy/mm/dd'), 2580, NULL , 30);
INSERT INTO EMP VALUES (7782, 'CLARK', 'MANAGER', 7839,
TO_DATE('1981-6-9', 'yyyy/mm/dd'), 2450, NULL , 10);
INSERT INTO EMP VALUES (7788, 'SCOTT', 'ANALYST', 7566,
TO_DATE('1987-4-19', 'yyyy/mm/dd'), 3000, NULL , 20);
INSERT INTO EMP VALUES (7839, 'KING', 'PRESIDENT', NULL,
TO_DATE('1981-11-17', 'yyyy/mm/dd'), 5000, NULL , NULL);
INSERT INTO EMP VALUES (7844, 'TURNER', 'SALESMAN', 7698,
TO_DATE('1981-9-8', 'yyyy/mm/dd'), 1500, 0 , 30);
INSERT INTO EMP VALUES (7876, 'ADAMS', 'CLERK', 7788,
TO_DATE('1987-5-23', 'yyyy/mm/dd'), 1100, NULL , 20);
INSERT INTO EMP VALUES (7900, 'JAMES', 'CLERK', 7698,
TO_DATE('1981-12-3', 'yyyy/mm/dd'), 950, NULL , 30);
INSERT INTO EMP VALUES (7902, 'FORD', 'ANALYST', 7566,
TO_DATE('1981-12-3', 'yyyy/mm/dd'), 3000, NULL , 20);
INSERT INTO EMP VALUES (7934, 'MILLER', 'CLERK', 7782,
TO_DATE('1982-1-23', 'yyyy/mm/dd'), 1300, NULL , 10);
COMMIT;
[最終的に表示したい形]
マネージャー 人数 最高給料 最低給料 マネージャー名
7566 2 3000 3000 JONES
7698 5 1500 400 BLAKE
7782 1 1300 1300 CLARK
7788 1 1100 1100 SCOTT
7839 3 2975 2450 KING
7902 1 400 400 FORD
回答3件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2015/07/29 23:13