Using Null/ja

From SQLZoo
Language: Project:Language policy English  • 日本語  • 中文
教員 teacher
番号 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
...
学科 dept
番号 id 学科名 name
1 Computing
2 Design
3 Engineering
...

教員と学科

学校に学科がたくさんある。多くの教員が1つの学科だけに勤める。 学科に所属しない教員もいる。

NULL値の選択

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
Kaleidoscope - get a kaleidoscope view using your phone/laptop camera
  • Served by: noddy at 2026年07月05日T11:01