1. List all employees and their departments. (employee_name, department_name)
    SELECT Employee.name, Department.name AS department
    FROM Employee JOIN Department ON id_dep = Department.id
    
  2. List all departments and their directors. (department_name, director_name)
    SELECT Department.name AS department, Employee.name AS director
    FROM Employee JOIN Department ON id_dir = Employee.id
    
  3. List all projects and the department to which they belong. (project_name, department_name)
    SELECT Project.name, Department.name AS department
    FROM Project JOIN Department ON id_dep = Department.id
    
  4. What projects are controlled by the department number 1. (project_name)
    SELECT name
    FROM Project WHERE id_dep = 1
    
  5. What projects are controlled by the Transports Department. (project_name)
    SELECT Project.name
    FROM Project JOIN Department ON id_dep = Department.id
    WHERE Department.name = 'Transports'
    
  6. List all employees working on project XPTO and how many hours each one of them works in that project. (employee_name, hours)
    SELECT Employee.name, hours
    FROM Project JOIN
      Works ON id_pro = id JOIN
      Employee ON id_emp = Employee.id
    WHERE Project.name = 'XPTO'
    
  7. List all employees working on project XPTO and how many hours each one of them works in that project. Order the list from the employee that works more hours to the one that works less. (employee_name, hours)
    SELECT Employee.name, hours
    FROM Project JOIN
      Works ON id_pro = id JOIN
      Employee ON id_emp = Employee.id
    WHERE Project.name = 'XPTO'
    ORDER BY hours DESC
    
  8. How many employees work in each project? (project_name, number)
    SELECT name, COUNT(*)
    FROM Project JOIN Works ON id = id_pro
    GROUP BY id
    

    or

    SELECT name, COUNT(id_emp)
    FROM Project LEFT JOIN Works ON id = id_pro
    GROUP BY id
    
  9. How many hours are spent weekly in each project? (project_name, hours)
    SELECT name, SUM(hours)
    FROM Project JOIN Works ON id = id_pro
    GROUP BY id
    

    or

    SELECT name, SUM(hours)
    FROM Project LEFT JOIN Works ON id = id_pro
    GROUP BY id
    
  10. How many hours does each employee spends on projects every week? (employee_name, hours)
    SELECT name, SUM(hours)
    FROM Employee JOIN Works ON id = id_emp
    GROUP BY id
    
  11. List all employees and their superiors. (employee_name, superior_name)
    SELECT Employee.name, superior.name AS superior
    FROM Employee JOIN
     Employee AS superior ON Employee.id_sup = superior.id
    
  12. List all employees and their superiors. If the employee does not have a superior list it anyway with a NULL superior. (employee_name, superior_name)
    SELECT Employee.name, superior.name AS superior
    FROM Employee LEFT JOIN
     Employee AS superior ON Employee.id_sup = superior.id
    
  13. What is the largest salary in each department? (department_name, salary)
    SELECT Department.name, MAX(salary)
    FROM Department JOIN Employee ON Department.id = id_dep
    GROUP BY Department.id
    
  14. What is the highest salary in the whole company? (salary)
    SELECT MAX(salary)
    FROM Employee
    
  15. What is the difference between the highest and lowest salaries in the company? (difference)
    SELECT MAX(salary) - MIN(salary) AS difference
    FROM Employee
    
  16. What is the salary difference between each employee and his superior? (employee_name, superior_name, difference)
    SELECT Employee.name, superior.name AS superior,
       superior.salary - Employee.salary  AS difference
    FROM Employee JOIN
     Employee AS superior ON Employee.id_sup = superior.id
    
  17. What is the biggest difference between the salary of an employee and his superior? (difference)
    SELECT MAX(difference)
    FROM (
      SELECT ABS(superior.salary - Employee.salary) AS difference
      FROM Employee JOIN
     Employee AS superior ON Employee.id_sup = superior.id
    ) AS t
    
  18. List the departments where the average salary is more than 1300 euros? (department_name)
    SELECT Department.name, AVG(salary)
    FROM Department JOIN Employee ON id_dep = Department.id
    GROUP BY Department.id
    HAVING AVG(salary) > 1300
    
  19. List the employees who work on projects external to their department? (employee_name)
    SELECT Employee.name
    FROM Employee JOIN
     Works ON id_emp = id JOIN
     Project ON id_pro = Project.id
    WHERE Employee.id_dep <> Project.id_dep
    GROUP BY Employee.id
    
  20. List the employees who work on projects internal to their department? (employee_name)
SELECT Employee.name
FROM Employee JOIN
     Works ON id_emp = id JOIN
     Project ON id_pro = Project.id
WHERE Employee.id_dep = Project.id_dep
GROUP BY Employee.id
  1. List the employees who only work on projects internal to their department? (employee_name)
    SELECT Employee.name
    FROM Employee JOIN
     Works ON id_emp = id JOIN
     Project ON id_pro = Project.id
    WHERE Employee.id_dep = Project.id_dep AND
      Employee.id NOT IN (
        SELECT Employee.id
        FROM Employee JOIN
          Works ON id_emp = id JOIN
          Project ON id_pro = Project.id
        WHERE Employee.id_dep <> Project.id_dep
      )
    GROUP BY Employee.id
    

(Credits: André Restivo https://web.fe.up.pt/~arestivo)