Using Null/ja
From SQLZoo
番号 id | 学科 dept | 名前 name | 電話 phone | 携帯 mobile |
---|---|---|---|---|
101 | 1 | Shrivell | 2753 | 07986 555 1234 |
102 | 1 | Throd | 2754 | 07122 555 1920 |
103 | 1 | Splint | 2293 | |
104 | Spiregrain | 3287 | ||
105 | 2 | Cutflower | 3212 | 07996 555 6574 |
106 | Deadyawn | 3345 | ||
... |
番号 id | 学科名 name |
---|---|
1 | Computing |
2 | Design |
3 | Engineering |
... |
教員と学科
学校に学科がたくさんある。多くの教員が1つの学科だけに勤める。 学科に所属しない教員もいる。
Summary
NULL, INNER JOIN, LEFT JOIN, RIGHT JOIN
1.
学科がNULL値の教員をリストにする。
= を使えない理由
SELECT name
FROM teacher
WHERE dept IS NULL
result
2.
注意: 内部結合 INNER JOIN では学科に所属しない教員と教員のいない学科を見落とす。
SELECT teacher.name, dept.name
FROM teacher INNER JOIN dept
ON (teacher.dept=dept.id)
SELECT teacher.name, dept.name
FROM teacher INNER JOIN dept
ON (teacher.dept=dept.id)
result
3.
別の JOIN を使って全教員をリストにする。
SELECT teacher.name, dept.name
FROM teacher
LEFT JOIN dept ON (teacher.dept=dept.id)
result
4.
別の JOIN を使って全学科をリストにする。
SELECT teacher.name, dept.name
FROM teacher
RIGHT JOIN dept ON (teacher.dept=dept.id)
result
COALESCE関数を使う
5.
COALESCE関数で携帯番号を出力する。番号が無い場合は'07986 444 2266'を代わりに使う。 教員teacherの名前nameと携帯番号mobileか代わりに'07986 444 2266'出力する。
SELECT name, COALESCE(mobile,'07986 444 2266')
FROM teacher
result
6.
COALESCE関数とLEFT JOINで教員teacherの名前nameと学科名を出力する。 学科が無い時は'None'を代わりに使う。
SELECT teacher.name, COALESCE(dept.name,'None')
FROM teacher LEFT JOIN dept
ON teacher.dept=dept.id
result
7.
COUNTで教員数と携帯の数を数える。
SELECT COUNT(teacher.name), COUNT(mobile)
FROM teacher
result
8.
COUNTとGROUP BY dept.name で各学科ごとのスタッフ数を表示する。 RIGHT JOIN で工学科Engineeringをちゃんとリストに記載すること。
SELECT dept.name, COUNT(teacher.name)
FROM teacher RIGHT JOIN dept
ON teacher.dept=dept.id
GROUP BY dept.name
result
CASE/jaを使う
9.
CASEで各教員のnameの後ろに(訳者注 次のフィールドに)学科deptが1か2なら'Sci'それ以外なら'Art'を続ける。
SELECT name, CASE WHEN dept IN (1,2)
THEN 'Sci'
ELSE 'Art' END
FROM teacher
result
10.
CASEで各教員のnameの後ろに(訳者注 次のフィールドに)学科deptが1か2なら'Sci'、3なら'Art'、それ以外は'None'を続ける。
SELECT name, CASE WHEN dept IN (1,2)
THEN 'Sci'
WHEN dept = 3
THEN 'Art'
ELSE 'None' END
FROM teacher
result
Clear your results