Using Null/ja
From SQLZoo
| Language: Project:Language policy | English • 日本語 • 中文 |
|---|
| 番号 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
学科がNULL値の教員をリストにする。
dept=NULL と記述して動くと考えたと思う。しかし動かない。dept IS NULLと書く必要がある。
これは駄目だったけど、もっといい説明がこちらにある。Wikipedia:NULL.
SELECTname FROMteacher WHEREdeptISNULL
注意: 内部結合 INNER JOIN では学科に所属しない教員と教員のいない学科を見落とす。
SELECTteacher.name,dept.name FROMteacherINNERJOINdept ON(teacher.dept=dept.id)
SELECTteacher.name,dept.name FROMteacherINNERJOINdept ON(teacher.dept=dept.id)
別の JOIN を使って全教員をリストにする。
SELECTteacher.name,dept.name FROMteacher LEFTJOINdeptON(teacher.dept=dept.id)
別の JOIN を使って全学科をリストにする。
SELECTteacher.name,dept.name FROMteacher RIGHTJOINdeptON(teacher.dept=dept.id)
COALESCE関数を使う
COALESCE関数で携帯番号を出力する。番号が無い場合は'07986 444 2266'を代わりに使う。 教員teacherの名前nameと携帯番号mobileか代わりに'07986 444 2266'出力する。
SELECTname,COALESCE(mobile,'07986 444 2266') FROMteacher
COALESCE関数とLEFT JOINで教員teacherの名前nameと学科名を出力する。 学科が無い時は'None'を代わりに使う。
SELECTteacher.name,COALESCE(dept.name,'None') FROMteacherLEFTJOINdept ONteacher.dept=dept.id
COUNTで教員数と携帯の数を数える。
SELECTCOUNT(teacher.name),COUNT(mobile) FROMteacher
COUNTとGROUP BY dept.name で各学科ごとのスタッフ数を表示する。 RIGHT JOIN で工学科Engineeringをちゃんとリストに記載すること。
SELECTdept.name,COUNT(teacher.name) FROMteacherRIGHTJOINdept ONteacher.dept=dept.id GROUPBYdept.name
CASEを使う
CASEで各教員のnameの後ろに(訳者注 次のフィールドに)学科deptが1か2なら'Sci'それ以外なら'Art'を続ける。
SELECTname,CASEWHENdeptIN(1,2) THEN'Sci' ELSE'Art'END FROMteacher
CASEで各教員のnameの後ろに(訳者注 次のフィールドに)学科deptが1か2なら'Sci'、3なら'Art'、それ以外は'None'を続ける。
SELECTname,CASEWHENdeptIN(1,2) THEN'Sci' WHENdept=3 THEN'Art' ELSE'None'END FROMteacher
Clear your results
Retrieved from "https://sqlzoo.net/w/index.php?title=Using_Null/ja&oldid=40627"