-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path8_using_null.sql
105 lines (92 loc) · 3.26 KB
/
8_using_null.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
-- Exercise reference: https://sqlzoo.net/wiki/Using_Null
-- -----------------------------------------------------------------
-- Table samples:
--
-- teacher
-- | id | dept | name | phone | mobile |
-- |-----|------|------------|-------|----------------|
-- | 101 | | 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 |
-- ...
-- -----------------------------------------------------------------
-- List the teachers who have NULL for their department.
SELECT name
FROM teacher
WHERE dept IS NULL;
-- Note the INNER JOIN misses the teachers with no department and the
-- departments with no teacher.
SELECT teacher.name
,dept.name
FROM teacher
INNER JOIN dept
ON (teacher.dept = dept.id);
-- Use a different JOIN so that all teachers are listed.
SELECT teacher.name
,dept.name
FROM teacher
LEFT JOIN dept
ON (teacher.dept = dept.id);
-- Use a different JOIN so that all departments are listed.
SELECT teacher.name
,dept.name
FROM teacher
RIGHT JOIN dept
ON (teacher.dept = dept.id);
-- Use COALESCE to print the mobile number. Use the number '07986 444 2266' if
-- there is no number given.
-- Show teacher name and mobile number or '07986 444 2266'.
SELECT name
,COALESCE(mobile,'07986 444 2266') AS 'mobile number'
FROM teacher;
-- Use the COALESCE function and a LEFT JOIN to print the teacher name and
-- department name. Use the string 'None' where there is no department.
SELECT teacher.name
,COALESCE(dept.name,'None') AS department
FROM teacher
LEFT JOIN dept
ON teacher.dept = dept.id;
-- Use COUNT to show the number of teachers and the number of mobile phones.
SELECT COUNT(name)
,COUNT(mobile)
FROM teacher;
-- Use COUNT and GROUP BY dept.name to show each department and the number of
-- staff. Use a RIGHT JOIN to ensure that the Engineering department is listed.
SELECT dept.name
,COUNT(teacher.dept) AS 'stuff number'
FROM teacher
RIGHT JOIN dept
ON (teacher.dept = dept.id)
GROUP BY dept.name;
-- Use CASE to show the name of each teacher followed by 'Sci' if the teacher
-- is in dept 1 or 2 and 'Art' otherwise.
SELECT teacher.name
,CASE WHEN dept.id = 1 OR dept.id = 2
THEN 'Sci'
ELSE 'Art'
END
FROM teacher
LEFT JOIN dept
ON (teacher.dept = dept.id);
-- Use CASE to show the name of each teacher followed by 'Sci' if the teacher is
-- in dept 1 or 2, show 'Art' if the teacher's dept is 3 and 'None' otherwise.
SELECT teacher.name
,CASE WHEN dept.id = 1 OR dept.id = 2
THEN 'Sci'
WHEN dept.id = 3
THEN 'Art'
ELSE 'None'
END
FROM teacher
LEFT JOIN dept
ON (teacher.dept = dept.id);