質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

3回答

4061閲覧

SQL グループ化されていない列の表示

qwerty123

総合スコア26

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2015/07/29 08:58

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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

ベストアンサー

そこまでできれいれば、マネージャ名を相関サブクエリでさくっと取得すれば簡単だと思います。

sql

1SELECT 2 MGR AS マネージャー, 3 COUNT(MGR) AS 人数, 4 MAX(SAL) AS 最高給料, 5 MIN(SAL) AS 最低給料, 6 ( 7 SELECT ENAME FROM EMP E WHERE E.EMPNO = EMP.MGR 8 ) AS マネージャー名 9FROM EMP 10WHERE MGR IS NOT NULL 11GROUP BY MGR 12ORDER BY MGR ASC

http://sqlfiddle.com/#!4/ad325/1

投稿2015/07/29 10:02

ngyuki

総合スコア4514

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

qwerty123

2015/07/29 23:13

みなさんありがとうございます。 理解できました!
guest

0

これでどうでしょう?

SQL

1SELECT 2 MBR.MGR AS マネージャー 3 , MBR.人数 4 , MBR.最高給料 5 , MBR.最低給料 6 , MNG.ENAME AS マネージャー名 7FROM EMP MNG 8JOIN( 9 SELECT 10 MGR 11 , COUNT(MGR) AS 人数 12 , MAX(SAL) AS 最高給料 13 , MIN(SAL) AS 最低給料 14 FROM EMP 15 WHERE MGR IS NOT NULL 16 GROUP BY MGR 17) MBR 18ON MNG.EMPNO = MBR.MGR 19ORDER BY MNG.MGR ASC 20

投稿2015/07/29 09:52

編集2015/07/29 09:57
kutsulog

総合スコア985

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

こんにちは。
誤解があるかもしれませんが、
1例として下記のような方法があるかと思われます。

sql

1SELECT l.マネージャー, l.人数, l.最高給料, l.最低給料, m.ENAME AS マネージャー名 2FROM ( 3SELECT MGR AS マネージャー, COUNT(MGR) AS 人数, MAX(SAL) AS 最高給料, MIN(SAL) AS 最低給料 4FROM EMP 5WHERE MGR IS NOT NULL 6GROUP BY MGR 7) AS l, EMP AS m 8WHERE l.マネージャー = m.EMPNO 9ORDER BY l.マネージャー ASC

動作までさせていないので
このまますんなり動くかはわかりませんが
上のような感じかと思われます。

語弊を恐れずにざっくりと説明しますと、
質問にご記載のグループ化したデータをlテーブルとして
そこにマネージャー名を抽出するためEMP AS mをくっつけます。
グループ化したl.マネージャーにくっつけたm.EMPNOが一致したら
m.ENAMEをマネージャー名として出力するという意図になります。

投稿2015/07/29 09:46

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問