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

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

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

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

Q&A

解決済

2回答

1465閲覧

SQLの問題について解説をお願いします。

niconicodryyy

総合スコア36

SQL

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

0グッド

0クリップ

投稿2019/04/08 03:58

以下の問題は、オラクル、ブロンズSQLの白本の問題になります。回答を見ても納得できないのでどなたか解説をお願い致します。

EMPLOYEES表のEMPNO、ENAMEおよびMGRには、社員番号、社員名および上司の社員番号が登録されています。次のSQL文の実行結果として正しいものを選択しなさい。

SQL

1SELECT empno, ename FROM employees 2WHERE empno IN (SELECT empno FROM employees 3MINUS 4SELECT DISTINCT mgr FROM employees);

1,EMPLOYEES表から部下のいない社員の社員番号と社員名が表示される。
2,EMPLOYEES表から上司のいない社員の社員番号と社員名が表示される。

正解は1なります。

私考えでは2になるかと思うんですが、なぜなら
仮にEMPNOに1,2,3,4,5
MGRに4,5とあるとしたら
副問い合わせで返ってくる数値は1,2,3ですよね?
4,5が上司の番号なのですから残りの1,2,3は部下の番号になり
2の上司のいない番号が戻されるが正解と思ったのですが、違うみたいです。
どなたか解説をお願い致します。

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

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

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

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

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

sazi

2019/04/08 04:03 編集

employeesの内容についての解説はありませんか? 若しくは問題そのもののURLなどがあれば追記して下さい。
m.ts10806

2019/04/08 04:25

タイトルだけだと質問ではなく依頼なのでその「納得できないところ」を具体化したタイトルにされた方が良いかと思います
niconicodryyy

2019/04/08 04:26

employeesの内容についての解説は特に無く 問題自体、私が問題集から模写していますので、URLとはありません。 選択肢を少なくしているだけで、上記の問題は問題集の問題と一語一句変わりません。
guest

回答2

0

ベストアンサー

mgrは上司のempnoが設定されるとして、以下の様なデータだった場合

empnomgr
14
25
31
4
5

1.EMPLOYEES表から部下のいない社員の社員番号

即ち、上司としての登録が無いものですから、mgrに登録のないempnoです。

2.EMPLOYEES表から上司のいない社員の社員番号

mgrに値が設定されていないものです。

選択肢の内容のSQLを先ず考えて、問いのSQLと比較してみるとはっきりします。

副問い合わせで返ってくる数値は1,2,3ですよね?
4,5が上司の番号なのですから残りの1,2,3は部下の番号になり
2の上司のいない番号が戻されるが正解と思ったのですが

「1,2,3は部下の番号」と「2の上司のいない番号が戻される」は、「部下なのに上司はいない」となっていて矛盾してますよ。

投稿2019/04/08 04:24

編集2019/04/09 05:16
sazi

総合スコア25195

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

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

0

副問い合わせで返ってくる数値は1,2,3ですよね?

ここまでの解釈はOKです。

複問い合わせの mgr はEMPNO全体のなかで、上司として登録されている社員です。
全社員(複問い合わせの empno)から上記を MINUS すると、のこりは、上司として登録されてない社員です。

投稿2019/04/08 04:13

編集2019/04/08 04:15
hihijiji

総合スコア4150

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問