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

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

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

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

解決済

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

qwerty123
qwerty123

総合スコア26

SQL

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

3回答

0評価

0クリップ

2770閲覧

投稿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

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

解決済

回答2

クリップ0

更新

2015/08/02

SQL

同じタグがついた質問を見る

SQL

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