-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPracticeTasks-10.sql
291 lines (263 loc) · 7.1 KB
/
PracticeTasks-10.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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
CREATE TABLE Students (
student_id INT PRIMARY KEY,
first_name VARCHAR(50),
last_name VARCHAR(50),
date_of_birth DATE
);
CREATE TABLE Courses (
course_id INT PRIMARY KEY,
course_name VARCHAR(100),
instructor VARCHAR(100)
);
CREATE TABLE Enrollments (
enrollment_id INT PRIMARY KEY,
student_id INT,
course_id INT,
enrollment_date DATE,
FOREIGN KEY (student_id) REFERENCES Students(student_id),
FOREIGN KEY (course_id) REFERENCES Courses(course_id)
);
INSERT INTO Students (student_id, first_name, last_name, date_of_birth)
VALUES
(1, 'John', 'Doe', '1995-05-15'),
(2, 'Jane', 'Smith', '1998-09-20'),
(3, 'Alice', 'Johnson', '1997-03-13'),
(4, 'Ella', 'Johnson', '1996-07-12'),
(5, 'Liam', 'Brown', '1999-02-25'),
(6, 'Ava', 'Miller', '1998-11-18'),
(7, 'Noah', 'Garcia', '1997-09-03'),
(8, 'Olivia', 'Martinez', '1996-04-29'),
(9, 'Emma', 'Lopez', '1998-06-21'),
(10, 'William', 'Davis', '1997-03-14'),
(11, 'Sophia', 'Rodriguez', '1999-08-05'),
(12, 'James', 'Hernandez', '1995-12-08'),
(13, 'Charlotte', 'Young', '1996-10-17'),
(14, 'Benjamin', 'Lee', '1998-05-20'),
(15, 'Amelia', 'Walker', '1997-01-23');
INSERT INTO Courses (course_id, course_name, instructor)
VALUES
(101, 'Introduction to Database', 'Professor Smith'),
(102, 'Web Development Basics', 'Professor Johnson'),
(103, 'Data Analysis Techniques', 'Professor Brown'),
(104, 'Advanced Database Management', 'Professor Johnson'),
(105, 'Data Mining Techniques', 'Professor Lee'),
(106, 'Web Application Development', 'Professor Martinez'),
(107, 'Software Engineering Principles', 'Professor Davis'),
(108, 'Network Security Fundamentals', 'Professor Rodriguez'),
(109, 'Artificial Intelligence Fundamentals', 'Professor Hernandez'),
(110, 'Database Design and Optimization', 'Professor Young'),
(111, 'Mobile App Development', 'Professor Walker'),
(112, 'Cloud Computing Technologies', 'Professor Moore'),
(113, 'Human-Computer Interaction', 'Professor Turner'),
(114, 'Business Analytics', 'Professor Perez'),
(115, 'Computer Graphics and Visualization', 'Professor Foster');
INSERT INTO Enrollments (enrollment_id, student_id, course_id, enrollment_date)
VALUES
(1, 1, 101, '2023-01-15'),
(2, 1, 102, '2023-02-20'),
(3, 2, 101, '2023-01-15'),
(4, 3, 103, '2023-03-05'),
(5, 4, 104, '2023-02-10'),
(6, 5, 105, '2023-03-15'),
(7, 6, 106, '2023-01-22'),
(8, 7, 107, '2023-04-05'),
(9, 8, 108, '2023-02-28'),
(10, 10, 109, '2023-01-10'),
(11, 10, 110, '2023-03-18'),
(12, 11, 112, '2023-02-08'),
(13, 12, 112, '2023-03-02'),
(14, 13, 113, '2023-04-12'),
(15, 14, 114, '2023-01-29'),
(16, 15, 115, '2023-03-21');
select * from students;
select * from Courses;
select * from enrollments;
--1
create view studentlist as
select
student_id,
concat(first_name, ' ', last_name) as full_name,
date_of_birth
from
students;
--2
select
student_id,
full_name,
date_of_birth
from
studentlist
order by
student_id
limit 5;
--3
create view studentlist2 as
select
student_id,
concat(first_name, ' ', last_name) as full_name,
date_of_birth,
datediff(year, date_of_birth, getdate()) -
case
when dateadd(year, datediff(year, date_of_birth, getdate()), date_of_birth) > getdate()
then 1
else 0
end as age
from
students;
--4
create view courseenrollments as
select
c.course_id,
c.course_name,
c.instructor,
count(e.student_id) as num_students_enrolled
from
courses c
left join
enrollments e on c.course_id = e.course_id
group by
c.course_id, c.course_name, c.instructor;
--5
select top 1
course_id,
course_name,
instructor,
num_students_enrolled
from
courseenrollments
order by
num_students_enrolled desc;
--6
create or alter view courseenrollments as
select
c.course_id,
c.course_name,
c.instructor,
count(e.student_id) as num_students_enrolled
from
courses c
left join
enrollments e on c.course_id = e.course_id
group by
c.course_id, c.course_name, c.instructor;
--7
with mostenrolledcourse as (
select top 1
ce.course_id,
ce.course_name,
ce.instructor
from
courseenrollments ce
order by
ce.num_students_enrolled desc
)
select
mec.course_name as most_enrolled_course,
mec.instructor as instructor,
sl.full_name as student_name
from
mostenrolledcourse mec
join
enrollments e on mec.course_id = e.course_id
join
studentlist sl on e.student_id = sl.student_id;
--8
drop view if exists studentlist;
drop view if exists courseenrollments;
--9
create view studentcoursecount as
select
concat(first_name, ' ', last_name) as full_name,
count(*) as course_count
from
students s
join
enrollments e on s.student_id = e.student_id
group by
s.student_id, s.first_name, s.last_name;
--10
with rankedstudents as (
select
full_name,
course_count,
rank() over (order by course_count desc) as rank
from
studentcoursecount
)
select
full_name,
course_count
from
rankedstudents
where
rank = 1;
--11
create view instructorcoursecount as
select
instructor,
count(*) as course_count
from
courses
group by
instructor;
--12
select instructor, course_count
from instructorcoursecount
where course_count = (
select max(course_count)
from instructorcoursecount
);
--13
create view studentenrollments as
select
concat(s.first_name, ' ', s.last_name) as full_name,
string_agg(c.course_name, ', ') as enrolled_courses
from
students s
join
enrollments e on s.student_id = e.student_id
join
courses c on e.course_id = c.course_id
group by
s.student_id, s.first_name, s.last_name;
--14
with mostenrolledstudent as (
select top 1
full_name
from
studentcoursecount
order by
course_count desc
),
instructorsformostenrolledcourses as (
select
mec.full_name as most_enrolled_student,
se.enrolled_courses,
icc.instructor
from
mostenrolledstudent mec
join
studentenrollments se on mec.full_name = se.full_name
join
courses c on se.enrolled_courses like '%' + c.course_name + '%'
join
instructorcoursecount icc on c.instructor = icc.instructor
)
select
most_enrolled_student as student,
instructor as instructor,
enrolled_courses as courses_taught
from
instructorsformostenrolledcourses;
--15
create view studentcourseinfo as
select
concat(s.first_name, ' ', s.last_name) as full_name,
c.course_name,
c.instructor
from
students s
join
enrollments e on s.student_id = e.student_id
join
courses c on e.course_id = c.course_id;