SQL. Puzzle divertenti

Ciao Habr!

Per più di 3 anni, aghju insignatu SQL in diversi centri di furmazione, è una di e mo osservazioni hè chì i studienti maestranu è capiscenu megliu SQL s'ellu sò datu un compitu, è micca solu parlà di e pussibulità è fundamenti teorichi.

In questu articulu, sparteraghju cun voi a mo lista di i travaglii chì dete à i studienti cum'è travaglii in casa è nantu à quale conducemu diversi tipi di brainstorms, chì porta à una cunniscenza profonda è chjara di SQL.

SQL. Puzzle divertenti

SQL (ˈɛsˈkjuˈɛl; eng. linguaggio di query strutturatu) hè un linguaghju di prugrammazione dichjarazione utilizatu per creà, mudificà è gestisce e dati in una basa di dati relazionale gestita da un sistema di gestione di basa di dati adattatu. Saperne di più

Pudete leghje nantu à SQL da diverse fonti.
Questu articulu ùn hè micca pensatu à insegnà SQL da zero.

Allora andemu

Avemu aduprà u bè cunnisciutu- schema HR in Oracle cù e so tavule (More):

SQL. Puzzle divertenti
Aghju nutatu chì avemu da cunsiderà solu i travaglii nantu à SELECT. Ùn ci sò micca compiti nantu à DML è DDL.

fatti

Restrizzione è Sorting Data

Tavola di l'impiegati. Ottene una lista cù infurmazioni nantu à tutti l'impiegati
dicisioni

SELECT * FROM employees

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chjamati "David"
dicisioni

SELECT *
  FROM employees
 WHERE first_name = 'David';

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati cù job_id uguale à 'IT_PROG'
dicisioni

SELECT *
  FROM employees
 WHERE job_id = 'IT_PROG'

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati da u 50u dipartimentu (department_id) cù un salariu (salariu) più grande di 4000
dicisioni

SELECT *
  FROM employees
 WHERE department_id = 50 AND salary > 4000;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati da u 20 è da u 30 dipartimentu (department_id)
dicisioni

SELECT *
  FROM employees
 WHERE department_id = 20 OR department_id = 30;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì l'ultima lettera in u so nome hè "a"
dicisioni

SELECT *
  FROM employees
 WHERE first_name LIKE '%a';

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati da u 50 è da u dipartimentu 80 (department_id) chì anu un bonus (u valore in a colonna commission_pct ùn hè micca viotu)
dicisioni

SELECT *
  FROM employees
 WHERE     (department_id = 50 OR department_id = 80)
       AND commission_pct IS NOT NULL;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì u nome cuntene almenu 2 lettere "n"
dicisioni

SELECT *
  FROM employees
 WHERE first_name LIKE '%n%n%';

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì u nome hè più di 4 lettere
dicisioni

SELECT *
  FROM employees
 WHERE first_name LIKE '%_____%';

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì u salariu hè trà 8000 è 9000 (inclusive)
dicisioni

SELECT *
  FROM employees
 WHERE salary BETWEEN 8000 AND 9000;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì u nome cuntene u simbulu '%'
dicisioni

SELECT *
  FROM employees
 WHERE first_name LIKE '%%%' ESCAPE '';

Tavola di l'impiegati. Ottene una lista di tutti l'ID manager
dicisioni

SELECT DISTINCT manager_id
  FROM employees
 WHERE manager_id IS NOT NULL;

Tavola di l'impiegati. Ottene una lista di l'impiegati cù e so pusizioni in u furmatu: Donald(sh_clerk)
dicisioni

SELECT first_name || '(' || LOWER (job_id) || ')' employee FROM employees;

Utilizà e funzioni di una sola fila per persunalizà l'output

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì u nome hè più di 10 lettere
dicisioni

SELECT *
  FROM employees
 WHERE LENGTH (first_name) > 10;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì anu a lettera "b" in u so nome (insensibile à u casu)
dicisioni

SELECT *
  FROM employees
 WHERE INSTR (LOWER (first_name), 'b') > 0;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì u nome cuntene almenu 2 lettere "a"
dicisioni

SELECT *
  FROM employees
 WHERE INSTR (LOWER (first_name),'a',1,2) > 0;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì u salariu hè un multiplu di 1000
dicisioni

SELECT *
  FROM employees
 WHERE MOD (salary, 1000) = 0;

Tavola di l'impiegati. Ottene u primu numeru di 3 cifre di u numeru di telefunu di l'impiigatu se u so numeru hè in u furmatu ХХХ.ХХХ.ХХХХ
dicisioni

SELECT phone_number, SUBSTR (phone_number, 1, 3) new_phone_number
  FROM employees
 WHERE phone_number LIKE '___.___.____';

Tavola di dipartimenti. Ottene a prima parolla da u nome di u dipartimentu per quelli chì anu più di una parolla in u nome
dicisioni

SELECT department_name,
       SUBSTR (department_name, 1, INSTR (department_name, ' ')-1)
           first_word
  FROM departments
 WHERE INSTR (department_name, ' ') > 0;

Tavola di l'impiegati. Ottene i nomi di l'impiegati senza a prima è l'ultima lettera in u nome
dicisioni

SELECT first_name, SUBSTR (first_name, 2, LENGTH (first_name) - 2) new_name
  FROM employees;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì l'ultima lettera in u nome hè uguale à "m" è a durata di u nome hè più grande di 5
dicisioni

SELECT *
  FROM employees
 WHERE SUBSTR (first_name, -1) = 'm' AND LENGTH(first_name)>5;

Tavola doppia. Pigliate a data di vennari prossimu
dicisioni

SELECT NEXT_DAY (SYSDATE, 'FRIDAY') next_friday FROM DUAL;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì sò stati cù a cumpagnia per più di 17 anni
dicisioni

SELECT *
  FROM employees
 WHERE MONTHS_BETWEEN (SYSDATE, hire_date) / 12 > 17;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì l'ultimu cifru di u numeru di telefunu hè stranu è hè custituitu da 3 numeri separati da un puntu
dicisioni

SELECT *
  FROM employees
 WHERE     MOD (SUBSTR (phone_number, -1), 2) != 0
       AND INSTR (phone_number,'.',1,3) = 0;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati chì u valore job_id dopu à u signu '_' hà almenu 3 caratteri, ma questu valore dopu à '_' ùn hè micca uguale à 'CLERK'
dicisioni

SELECT *
  FROM employees
 WHERE     LENGTH (SUBSTR (job_id, INSTR (job_id, '_') + 1)) > 3
       AND SUBSTR (job_id, INSTR (job_id, '_') + 1) != 'CLERK';

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati rimpiazzendu tutti "." in u valore PHONE_NUMBER nantu à '-'
dicisioni

SELECT phone_number, REPLACE (phone_number, '.', '-') new_phone_number
  FROM employees;

Utilizà Funzioni di Cunversione è Espressioni Cundiziunali

Tavola di l'impiegati. Pigliate una lista di tutti l'impiegati chì sò ghjunti à travaglià u primu ghjornu di u mese (qualsiasi)
dicisioni

SELECT *
  FROM employees
 WHERE TO_CHAR (hire_date, 'DD') = '01';

Tavola di l'impiegati. Pigliate una lista di tutti l'impiegati chì sò ghjunti à travaglià in u 2008
dicisioni

SELECT *
  FROM employees
 WHERE TO_CHAR (hire_date, 'YYYY') = '2008';

DUAL table. Mostra a data di dumane in u furmatu: Dumani hè u secondu ghjornu di ghjennaghju
dicisioni

SELECT TO_CHAR (SYSDATE, 'fm""Tomorrow is ""Ddspth ""day of"" Month')     info
  FROM DUAL;

Tavola di l'impiegati. Pigliate una lista di tutti l'impiegati è a so data di iniziu in u furmatu: 21 di ghjugnu, 2007
dicisioni

SELECT first_name, TO_CHAR (hire_date, 'fmddth ""of"" Month, YYYY') hire_date
  FROM employees;

Tavola di l'impiegati. Ottene una lista di l'impiegati cù salari aumentati da 20%. Mostra u salariu cù u segnu di u dollaru
dicisioni

SELECT first_name, TO_CHAR (salary + salary * 0.20, 'fm$999,999.00') new_salary
  FROM employees;

Tavola di l'impiegati. Pigliate una lista di tutti l'impiegati chì sò ghjunti à travaglià in u ferraghju 2007.
dicisioni

SELECT *
  FROM employees
 WHERE hire_date BETWEEN TO_DATE ('01.02.2007', 'DD.MM.YYYY')
                     AND LAST_DAY (TO_DATE ('01.02.2007', 'DD.MM.YYYY'));

SELECT *
  FROM employees
 WHERE to_char(hire_date,'MM.YYYY') = '02.2007'; 

DUAL table. Esporta a data attuale, + secondu, + minutu, + ora, + ghjornu, + mese, + annu
dicisioni

SELECT SYSDATE                          now,
       SYSDATE + 1 / (24 * 60 * 60)     plus_second,
       SYSDATE + 1 / (24 * 60)          plus_minute,
       SYSDATE + 1 / 24                 plus_hour,
       SYSDATE + 1                      plus_day,
       ADD_MONTHS (SYSDATE, 1)          plus_month,
       ADD_MONTHS (SYSDATE, 12)         plus_year
  FROM DUAL;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati cù i salarii cumpleti (salariu + commission_pct (%)) in u furmatu: $ 24,000.00
dicisioni

SELECT first_name, salary, TO_CHAR (salary + salary * NVL (commission_pct, 0), 'fm$99,999.00') full_salary
  FROM employees;

Tavola di l'impiegati. Ottene una lista di tutti l'impiegati è l'infurmazioni nantu à a dispunibilità di bonus di salari (Sì / No)
dicisioni

SELECT first_name, commission_pct, NVL2 (commission_pct, 'Yes', 'No') has_bonus
  FROM employees;

Tavola di l'impiegati. Ottene u livellu di u salariu di ogni impiigatu: Meno di 5000 hè cunsideratu Livellu Bassu, Più grande o uguale à 5000 è menu di 10000 hè cunsideratu Livellu Normale, Più o uguale à 10000 hè cunsideratu Altu Livellu
dicisioni

SELECT first_name,
       salary,
       CASE
           WHEN salary < 5000 THEN 'Low'
           WHEN salary >= 5000 AND salary < 10000 THEN 'Normal'
           ELSE 'High'
       END salary_level
  FROM employees;

Tavola di i paesi. Per ogni paese, mostra a regione in quale si trova: 1-Europa, 2-America, 3-Asia, 4-Africa (senza Join)
dicisioni

SELECT country_name country,
       DECODE (region_id,
               1, 'Europe',
               2, 'America',
               3, 'Asia',
               4, 'Africa',
               'Unknown')
           region
  FROM countries;

SELECT country_name
           country,
       CASE region_id
           WHEN 1 THEN 'Europe'
           WHEN 2 THEN 'America'
           WHEN 3 THEN 'Asia'
           WHEN 4 THEN 'Africa'
           ELSE 'Unknown'
       END
           region
  FROM countries;

Reporting Dati Aggregati Utilizendu e Funzioni di Gruppu

Tavola di l'impiegati. Ottene un rapportu per Department_id cù u salariu minimu è massimu, e date d'arrivu prima è tardi è u numeru di impiegati. Ordine per numeru di impiegati (desc)
dicisioni

  SELECT department_id,
         MIN (salary) min_salary,
         MAX (salary) max_salary,
         MIN (hire_date) min_hire_date,
         MAX (hire_date) max_hire_Date,
         COUNT (*) count
    FROM employees
GROUP BY department_id
order by count(*) desc;

Tavola di l'impiegati. Quantu impiegati chì i nomi cumincianu cù a stessa lettera? Sorte per quantità. Mostra solu quelli induve u numeru hè più grande di 1
dicisioni

SELECT SUBSTR (first_name, 1, 1) first_char, COUNT (*)
    FROM employees
GROUP BY SUBSTR (first_name, 1, 1)
  HAVING COUNT (*) > 1
ORDER BY 2 DESC;

Tavola di l'impiegati. Quanti impiegati travaglianu in u stessu dipartimentu è ricevenu u listessu salariu?
dicisioni

SELECT department_id, salary, COUNT (*)
    FROM employees
GROUP BY department_id, salary
  HAVING COUNT (*) > 1;

Tavola di l'impiegati. Pigliate un rapportu di quanti impiegati sò stati assuciati in ogni ghjornu di a settimana. Sorte per quantità
dicisioni

SELECT TO_CHAR (hire_Date, 'Day') day, COUNT (*)
    FROM employees
GROUP BY TO_CHAR (hire_Date, 'Day')
ORDER BY 2 DESC;

Tavola di l'impiegati. Pigliate un rapportu nantu à quanti impiegati sò stati assuciati per annu. Sorte per quantità
dicisioni

SELECT TO_CHAR (hire_date, 'YYYY') year, COUNT (*)
    FROM employees
GROUP BY TO_CHAR (hire_date, 'YYYY');

Tavola di l'impiegati. Ottene u numeru di dipartimenti chì anu impiegati
dicisioni

SELECT COUNT (COUNT (*))     department_count
    FROM employees
   WHERE department_id IS NOT NULL
GROUP BY department_id;

Tavola di l'impiegati. Ottene una lista di Department_id cù più di 30 impiegati
dicisioni

  SELECT department_id
    FROM employees
GROUP BY department_id
  HAVING COUNT (*) > 30;

Tavola di l'impiegati. Ottene una lista di Department_ids è u salariu mediu arrotondatu di l'impiegati in ogni dipartimentu.
dicisioni

  SELECT department_id, ROUND (AVG (salary)) avg_salary
    FROM employees
GROUP BY department_id;

Tavola di i paesi. Ottene una lista di region_id summa di tutte e lettere di tutti i paesi_name in quale più di 60
dicisioni

  SELECT region_id
    FROM countries
GROUP BY region_id
  HAVING SUM (LENGTH (country_name)) > 60;

Tavola di l'impiegati. Ottene una lista di department_id in quale travaglianu l'impiegati di parechji (> 1) job_id
dicisioni

  SELECT department_id
    FROM employees
GROUP BY department_id
  HAVING COUNT (DISTINCT job_id) > 1;

Tavola di l'impiegati. Ottene una lista di manager_id chì u numeru di subordinati hè più grande di 5 è a summa di tutti i salarii di i so subordinati hè più grande di 50000
dicisioni

  SELECT manager_id
    FROM employees
GROUP BY manager_id
  HAVING COUNT (*) > 5 AND SUM (salary) > 50000;

Tavola di l'impiegati. Ottene una lista di manager_id chì u salariu mediu di tutti i so subordinati hè trà 6000 è 9000 chì ùn ricevenu micca bonus (commission_pct hè viotu)
dicisioni

  SELECT manager_id, AVG (salary) avg_salary
    FROM employees
   WHERE commission_pct IS NULL
GROUP BY manager_id
  HAVING AVG (salary) BETWEEN 6000 AND 9000;

Tavola di l'impiegati. Ottene u salariu massimu da tutti l'impiegati job_id chì finisce cù a parolla "CLERK"
dicisioni

SELECT MAX (salary) max_salary
  FROM employees
 WHERE job_id LIKE '%CLERK';

SELECT MAX (salary) max_salary
  FROM employees
 WHERE SUBSTR (job_id, -5) = 'CLERK';

Tavola di l'impiegati. Ottene u salariu massimu trà tutti i salarii medii per u dipartimentu
dicisioni

  SELECT MAX (AVG (salary))
    FROM employees
GROUP BY department_id;

Tavola di l'impiegati. Ottene u numeru di impiegati cù u listessu numeru di lettere in u so nome. À u listessu tempu, mostra solu quelli chì u nome hè più longu di 5 è u numeru di impiegati cù u stessu nome hè più di 20. Sort by name length
dicisioni

  SELECT LENGTH (first_name), COUNT (*)
    FROM employees
GROUP BY LENGTH (first_name)
  HAVING LENGTH (first_name) > 5 AND COUNT (*) > 20
ORDER BY LENGTH (first_name);

  SELECT LENGTH (first_name), COUNT (*)
    FROM employees
   WHERE LENGTH (first_name) > 5
GROUP BY LENGTH (first_name)
  HAVING COUNT (*) > 20
ORDER BY LENGTH (first_name);

Visualizzazione di Dati da Multiple Tables Utilizendu Joins

Tavola Impiegati, Dipartimenti, Lochi, Paesi, Regioni. Pigliate una lista di e regioni è u numeru di impiegati in ogni regione
dicisioni

  SELECT region_name, COUNT (*)
    FROM employees e
         JOIN departments d ON (e.department_id = d.department_id)
         JOIN locations l ON (d.location_id = l.location_id)
         JOIN countries c ON (l.country_id = c.country_id)
         JOIN regions r ON (c.region_id = r.region_id)
GROUP BY region_name;

Tavola Impiegati, Dipartimenti, Lochi, Paesi, Regioni. Ottene infurmazioni detallate nantu à ogni impiigatu:
Cognome, Cognome, Dipartimentu, Job, Strada, Paese, Regione
dicisioni

SELECT First_name,
       Last_name,
       Department_name,
       Job_id,
       street_address,
       Country_name,
       Region_name
  FROM employees  e
       JOIN departments d ON (e.department_id = d.department_id)
       JOIN locations l ON (d.location_id = l.location_id)
       JOIN countries c ON (l.country_id = c.country_id)
       JOIN regions r ON (c.region_id = r.region_id);

Tavola di l'impiegati. Mostra tutti i gestori chì anu più di 6 impiegati
dicisioni

  SELECT man.first_name, COUNT (*)
    FROM employees emp JOIN employees man ON (emp.manager_id = man.employee_id)
GROUP BY man.first_name
  HAVING COUNT (*) > 6;

Tavola di l'impiegati. Mostra tutti l'impiegati chì ùn informanu à nimu
dicisioni

SELECT emp.first_name
  FROM employees  emp
       LEFT JOIN employees man ON (emp.manager_id = man.employee_id)
 WHERE man.FIRST_NAME IS NULL;

SELECT first_name
  FROM employees
 WHERE manager_id IS NULL;

Tavola di l'impiegati, Job_history. A tavola di l'Impiegati guarda tutti l'impiegati. A tavola Job_history guarda l'impiegati chì anu lasciatu a cumpagnia. Pigliate un rapportu nantu à tutti l'impiegati è u so statutu in l'impresa (Impiegati o abbandunati a cumpagnia cù a data di partenza)
Esempiu:
primu_nome | statutu
jennifer | Abbandunatu a cumpagnia à u 31 di dicembre di u 2006
Clara | Attualmente travaglia
dicisioni

SELECT first_name,
       NVL2 (
           end_date,
           TO_CHAR (end_date, 'fm""Left the company at"" DD ""of"" Month, YYYY'),
           'Currently Working')
           status
  FROM employees e LEFT JOIN job_history j ON (e.employee_id = j.employee_id);

Tavola Impiegati, Dipartimenti, Lochi, Paesi, Regioni. Ottene una lista di l'impiegati chì campanu in Europa (region_name)
dicisioni

 SELECT first_name
  FROM employees
       JOIN departments USING (department_id)
       JOIN locations USING (location_id)
       JOIN countries USING (country_id)
       JOIN regions USING (region_id)
 WHERE region_name = 'Europe';
 
 SELECT first_name
  FROM employees  e
       JOIN departments d ON (e.department_id = d.department_id)
       JOIN locations l ON (d.location_id = l.location_id)
       JOIN countries c ON (l.country_id = c.country_id)
       JOIN regions r ON (c.region_id = r.region_id)
 WHERE region_name = 'Europe';

Impiegati di Table, Dipartimenti. Mostra tutti i dipartimenti cù più di 30 impiegati
dicisioni

SELECT department_name, COUNT (*)
    FROM employees e JOIN departments d ON (e.department_id = d.department_id)
GROUP BY department_name
  HAVING COUNT (*) > 30;

Impiegati di Table, Dipartimenti. Mostra tutti l'impiegati chì ùn sò micca in ogni dipartimentu
dicisioni

SELECT first_name
  FROM employees  e
       LEFT JOIN departments d ON (e.department_id = d.department_id)
 WHERE d.department_name IS NULL;

SELECT first_name
  FROM employees
 WHERE department_id IS NULL;

Impiegati di Table, Dipartimenti. Mostra tutti i dipartimenti senza impiegati
dicisioni

SELECT department_name
  FROM employees  e
       RIGHT JOIN departments d ON (e.department_id = d.department_id)
 WHERE first_name IS NULL;

Tavola di l'impiegati. Mostra tutti l'impiegati chì ùn anu micca subordinati
dicisioni

SELECT man.first_name
  FROM employees  emp
       RIGHT JOIN employees man ON (emp.manager_id = man.employee_id)
 WHERE emp.FIRST_NAME IS NULL;

Impiegati di Table, Impieghi, Dipartimenti. Mostra l'impiegati in u formatu: First_name, Job_title, Department_name.
Esempiu:
primu_nome | titulu di travagliu | Nome_dipartimentu
Donald | spedizione | Clerk Shipping
dicisioni

SELECT first_name, job_title, department_name
  FROM employees  e
       JOIN jobs j ON (e.job_id = j.job_id)
       JOIN departments d ON (d.department_id = e.department_id);

Tavola di l'impiegati. Pigliate una lista di l'impiegati chì i so amministratori anu avutu un travagliu in u 2005, ma à u stessu tempu, sti travagliadori stessi anu un travagliu prima di u 2005.
dicisioni

SELECT emp.*
  FROM employees emp JOIN employees man ON (emp.manager_id = man.employee_id)
 WHERE     TO_CHAR (man.hire_date, 'YYYY') = '2005'
       AND emp.hire_date < TO_DATE ('01012005', 'DDMMYYYY');

Tavola di l'impiegati. Ottene una lista di l'impiegati chì i so dirigenti anu un travagliu in u mese di ghjennaghju di ogni annu è a durata di u job_title di questi impiegati hè più di 15 caratteri
dicisioni

SELECT emp.*
  FROM employees  emp
       JOIN employees man ON (emp.manager_id = man.employee_id)
       JOIN jobs j ON (emp.job_id = j.job_id)
 WHERE TO_CHAR (man.hire_date, 'MM') = '01' AND LENGTH (j.job_title) > 15;

Utilizà Subqueries per risolve e dumande

Tavola di l'impiegati. Pigliate una lista di l'impiegati cù u nome più longu.
dicisioni

SELECT *
  FROM employees
 WHERE LENGTH (first_name) =
       (SELECT MAX (LENGTH (first_name)) FROM employees);

Tavola di l'impiegati. Pigliate una lista di l'impiegati cù un salariu più grande di u salariu mediu di tutti l'impiegati.
dicisioni

SELECT *
  FROM employees
 WHERE salary > (SELECT AVG (salary) FROM employees);

Impiegati di Table, Dipartimenti, Lochi. Ottene a cità in quale l'impiegati guadagnanu u minimu in totale.
dicisioni

SELECT city
    FROM employees e
         JOIN departments d ON (e.department_id = d.department_id)
         JOIN locations l ON (d.location_id = l.location_id)
GROUP BY city
  HAVING SUM (salary) =
         (  SELECT MIN (SUM (salary))
              FROM employees e
                   JOIN departments d ON (e.department_id = d.department_id)
                   JOIN locations l ON (d.location_id = l.location_id)
          GROUP BY city);

Tavola di l'impiegati. Ottene una lista di l'impiegati chì u manager riceve un salariu di più di 15000 XNUMX.
dicisioni

SELECT *
  FROM employees
 WHERE manager_id IN (SELECT employee_id
                        FROM employees
                       WHERE salary > 15000)

Impiegati di Table, Dipartimenti. Mostra tutti i dipartimenti senza impiegati
dicisioni

SELECT *
  FROM departments
 WHERE department_id NOT IN (SELECT department_id
                               FROM employees
                              WHERE department_id IS NOT NULL);

Tavola di l'impiegati. Mostra tutti l'impiegati chì ùn sò micca amministratori
dicisioni

SELECT *
  FROM employees
 WHERE employee_id NOT IN (SELECT manager_id
                             FROM employees
                            WHERE manager_id IS NOT NULL)

Tavola di l'impiegati. Mostra tutti i gestori chì anu più di 6 impiegati
dicisioni

SELECT *
  FROM employees e
 WHERE (SELECT COUNT (*)
          FROM employees
         WHERE manager_id = e.employee_id) > 6;

Impiegati di Table, Dipartimenti. Mostra l'impiegati chì travaglianu in u dipartimentu IT
dicisioni

SELECT *
  FROM employees
 WHERE department_id = (SELECT department_id
                          FROM departments
                         WHERE department_name = 'IT');

Impiegati di Table, Impieghi, Dipartimenti. Mostra l'impiegati in u formatu: First_name, Job_title, Department_name.
Esempiu:
primu_nome | titulu di travagliu | Nome_dipartimentu
Donald | spedizione | Clerk Shipping
dicisioni

SELECT first_name,
       (SELECT job_title
          FROM jobs
         WHERE job_id = e.job_id)
           job_title,
       (SELECT department_name
          FROM departments
         WHERE department_id = e.department_id)
           department_name
  FROM employees e;

Tavola di l'impiegati. Pigliate una lista di l'impiegati chì i so amministratori anu avutu un travagliu in u 2005, ma à u stessu tempu, sti travagliadori stessi anu un travagliu prima di u 2005.
dicisioni

SELECT *
  FROM employees
 WHERE     manager_id IN (SELECT employee_id
                            FROM employees
                           WHERE TO_CHAR (hire_date, 'YYYY') = '2005')
       AND hire_date < TO_DATE ('01012005', 'DDMMYYYY');

Tavola di l'impiegati. Ottene una lista di l'impiegati chì i so dirigenti anu un travagliu in u mese di ghjennaghju di ogni annu è a durata di u job_title di questi impiegati hè più di 15 caratteri
dicisioni

SELECT *
  FROM employees e
 WHERE     manager_id IN (SELECT employee_id
                            FROM employees
                           WHERE TO_CHAR (hire_date, 'MM') = '01')
       AND (SELECT LENGTH (job_title)
              FROM jobs
             WHERE job_id = e.job_id) > 15;

Hè tuttu per avà.

Spergu chì i travaglii eranu interessanti è eccitanti.
Aghju aghjunghje à sta lista quantu pussibule.
Seraghju ancu cuntentu di qualsiasi cumenti è suggerimenti.

PS: Se qualchissia vene cun un compitu interessante nantu à SELECT, scrivite in i cumenti, aghju aghjunghje à a lista.

Спасибо.

Source: www.habr.com

Add a comment