Lab schema (HR schema) is listed as below (primary keys are underlined):
Regions(region_id, region_name);
Countries(country_id, country_name, region_id);
Locations(location_id, street_address, postal_code, city, state_province, country_id);
Departments(department_id, department_name, manager_id, location_id);
Jobs(job_id, job_title, min_salary, max_salary);
Employees(employee_id, first_name, last_name, email, phone_number, hire_date, job_id, salary, commission_pct, manager_id, department_id);
Job_History(employee_id, start_date, end_date, job_id, department_id);
Learning Objectives:
Write a single SQL query for each of the following questions.
select country_name, count(department_id) as numOfDepartments from Departments natural join Locations X right join Countries C on X.country_id = C.country_id group by country_name; select country_name, count(department_id) as numOfDepartments from Departments natural join Locations natural join Countries group by country_name union all select country_name, 0 as numOfDepartments from Countries where country_id not in (select country_id from Departments natural join Locations);
select department_name from Departments D join Employees E on D.department_id = E.department_id group by department_name having count(employee_id) >= 20;
select department_name, sum(salary), avg(salary) from Departments D join Employees E on D.department_id = E.department_id group by department_name having sum(salary) >= 40000;
select department_name from (select department_name, count(employee_id) as empCount from Departments D join Employees E on D.department_id = E.department_id group by department_name) X, (select max(empCount) as maxCount from (select department_name, count(employee_id) as empCount from Departments D join Employees E on D.department_id = E.department_id group by department_name) ) Y where empCount = maxCount;
select department_name from (select department_name, count(employee_id) empCount from Departments D join Employees E on D.department_id = E.department_id group by department_name) where empCount >= all (select count(employee_id) from Departments D join Employees E on D.department_id = E.department_id group by department_name);
select department_name from Departments D join Employees E on D.department_id = E.department_id group by department_id, department_name having count(employee_id) >= all (select count(employee_id) from Employees group by department_id);
select E1.first_name, E1.last_name from Employees E1, Employees E2 where E1.employee_id = E2.manager_id group by E1.first_name, E1.last_name having count(E2.employee_id) >= 5;
select first_name, last_name from (select E1.first_name, E1.last_name, count(E2.employee_id) subCount from Employees E1, Employees E2 where E1.employee_id = E2.manager_id group by E1.first_name, E1.last_name) where subCount >= 5;