SQL. Zabavne zagonetke

Pozdrav Habr!

Više od 3 godine predajem SQL u raznim trening centrima, a jedno od mojih zapažanja je da studenti bolje svladavaju i razumiju SQL ako im se zada zadatak, a ne samo pričaju o mogućnostima i teoretskim osnovama.

U ovom ću članku s vama podijeliti svoj popis zadataka koje studentima dajem kao domaću zadaću i na kojima provodimo razne vrste brainstorminga, što dovodi do dubokog i jasnog razumijevanja SQL-a.

SQL. Zabavne zagonetke

SQL (ˈɛsˈkjuˈɛl; eng. structured query language) je deklarativni programski jezik koji se koristi za kreiranje, modificiranje i upravljanje podacima u relacijskoj bazi podataka kojom upravlja odgovarajući sustav za upravljanje bazom podataka. Saznajte više

O SQL-u možete čitati iz različitih izvori.
Ovaj članak nije namijenjen da vas nauči SQL od nule.

Pa, idemo.

Koristit ćemo se poznatim HR shema u Oracleu sa svojim tablicama (Više):

SQL. Zabavne zagonetke
Napominjem da ćemo razmatrati samo zadatke na SELECT. Na DML i DDL nema zadataka.

zadaci

Ograničavanje i razvrstavanje podataka

Tablica zaposlenika. Dobijte popis s podacima o svim zaposlenicima
odluka

SELECT * FROM employees

Tablica zaposlenika. Dobijte popis svih zaposlenika koji se zovu 'David'
odluka

SELECT *
  FROM employees
 WHERE first_name = 'David';

Tablica zaposlenika. Dohvatite popis svih zaposlenika čiji je job_id jednak 'IT_PROG'
odluka

SELECT *
  FROM employees
 WHERE job_id = 'IT_PROG'

Tablica zaposlenika. Dobijte popis svih zaposlenika iz 50. odjela (department_id) s plaćom (salary) većom od 4000
odluka

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

Tablica zaposlenika. Dobiti popis svih zaposlenika iz 20. i iz 30. odjela (department_id)
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika čije je posljednje slovo u imenu 'a'
odluka

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

Tablica zaposlenika. Dobiti popis svih zaposlenika iz 50. i iz 80. odjela (department_id) koji imaju bonus (vrijednost u stupcu provizija_pct nije prazna)
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika čije ime sadrži najmanje 2 slova 'n'
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika čija su imena duža od 4 slova
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika čija je plaća između 8000 i 9000 (uključivo)
odluka

SELECT *
  FROM employees
 WHERE salary BETWEEN 8000 AND 9000;

Tablica zaposlenika. Dobijte popis svih zaposlenika čije ime sadrži simbol '%'
odluka

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

Tablica zaposlenika. Dobijte popis svih ID-ova upravitelja
odluka

SELECT DISTINCT manager_id
  FROM employees
 WHERE manager_id IS NOT NULL;

Tablica zaposlenika. Dobijte popis zaposlenika s njihovim pozicijama u formatu: Donald(sh_clerk)
odluka

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

Korištenje funkcija s jednim redom za prilagodbu izlaza

Tablica zaposlenika. Dobijte popis svih zaposlenika čija su imena duža od 10 slova
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika koji imaju slovo 'b' u svom imenu (neosjetljivo na velika i mala slova)
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika čije ime sadrži najmanje 2 slova 'a'
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika čija je plaća višekratnik 1000
odluka

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

Tablica zaposlenika. Dobiti prvi 3-znamenkasti broj telefonskog broja zaposlenika ako je njegov broj u formatu HHH.HHH.HHHH
odluka

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

Tablica odjela. Dobijte prvu riječ iz naziva odjela za one koji imaju više od jedne riječi u nazivu
odluka

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

Tablica zaposlenika. Dobijte imena zaposlenika bez prvog i zadnjeg slova u imenu
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika čije je zadnje slovo u imenu jednako 'm', a duljina imena veća od 5
odluka

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

Dvostruki stol. Dobijte datum sljedeći petak
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika koji su u tvrtki više od 17 godina
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika čija je zadnja znamenka telefonskog broja neparna i sastoji se od 3 broja odvojena točkom
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika čija vrijednost job_id iza znaka '_' ima najmanje 3 znaka, ali ova vrijednost nakon '_' nije jednaka 'CLERK'
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika zamjenom svih '.' u vrijednosti PHONE_NUMBER na '-'
odluka

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

Korištenje funkcija pretvorbe i uvjetnih izraza

Tablica zaposlenika. Dobijte popis svih zaposlenika koji su došli na posao prvog dana u mjesecu (bilo koji)
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika koji su došli na posao u 2008. godini
odluka

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

DUAL stol. Prikaži sutrašnji datum u formatu: Sutra je drugi dan siječnja
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika i njihov datum početka u formatu: 21. lipnja 2007
odluka

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

Tablica zaposlenika. Dobijte popis zaposlenika s povećanim plaćama za 20%. Prikažite plaću sa znakom dolara
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika koji su došli na posao u veljači 2007.
odluka

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 stol. Izvoz trenutnog datuma, + sekunda, + minuta, + sat, + dan, + mjesec, + godina
odluka

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;

Tablica zaposlenika. Dobijte popis svih zaposlenika s punim plaćama (plaća + provizija_pct(%)) u formatu: $24,000.00
odluka

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

Tablica zaposlenika. Dobijte popis svih zaposlenika i informacije o dostupnosti bonusa na plaću (Da/Ne)
odluka

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

Tablica zaposlenika. Dobijte razinu plaće svakog zaposlenika: Manje od 5000 smatra se niskom razinom, veće od ili jednako 5000 i manje od 10000 smatra se normalnom razinom, veće od ili jednako 10000 smatra se visokom razinom
odluka

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;

Tablica zemalja. Za svaku državu prikažite regiju u kojoj se nalazi: 1-Europa, 2-Amerika, 3-Azija, 4-Afrika (bez pridruživanja)
odluka

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;

Izvještavanje o agregiranim podacima pomoću grupnih funkcija

Tablica zaposlenika. Dobijte izvještaj po department_id s minimalnom i maksimalnom plaćom, datumima ranog i kasnog dolaska i brojem zaposlenika. Poredaj po broju zaposlenih (desc)
odluka

  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;

Tablica zaposlenika. Koliko ima zaposlenika čija imena počinju istim slovom? Poredaj po količini. Prikaži samo one gdje je broj veći od 1
odluka

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;

Tablica zaposlenika. Koliko zaposlenika radi u istom odjelu i prima istu plaću?
odluka

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

Tablica zaposlenika. Dobijte izvješće o tome koliko je zaposlenika bilo zaposleno svakog dana u tjednu. Poredaj po količini
odluka

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

Tablica zaposlenika. Dobijte izvješće o tome koliko je zaposlenika zaposleno po godinama. Poredaj po količini
odluka

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

Tablica zaposlenika. Dobijte broj odjela koji imaju zaposlene
odluka

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

Tablica zaposlenika. Dobijte popis department_id s više od 30 zaposlenika
odluka

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

Tablica zaposlenika. Dobijte popis department_ids i zaokruženu prosječnu plaću zaposlenika u svakom odjelu.
odluka

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

Tablica zemalja. Nabavite popis region_id zbroja svih slova svih naziva zemalja u kojima je više od 60
odluka

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

Tablica zaposlenika. Dobijte popis department_id u kojem rade zaposlenici nekoliko (>1) job_id
odluka

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

Tablica zaposlenika. Dobijte popis manager_id čiji je broj podređenih veći od 5 i zbroj svih plaća njegovih podređenih veći od 50000 XNUMX
odluka

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

Tablica zaposlenika. Nabavite popis manager_id čija je prosječna plaća svih njegovih podređenih između 6000 i 9000 koji ne primaju bonuse (commission_pct je prazan)
odluka

  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;

Tablica zaposlenika. Dobijte maksimalnu plaću od svih zaposlenika job_id koji završava riječju 'CLERK'
odluka

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';

Tablica zaposlenika. Dobijte maksimalnu plaću među svim prosječnim plaćama za odjel
odluka

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

Tablica zaposlenika. Dobijte broj zaposlenika s istim brojem slova u imenu. Istovremeno, prikazati samo one čije je ime duže od 5, a broj zaposlenika s istim imenom veći od 20. Poredaj po dužini imena
odluka

  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);

Prikaz podataka iz više tablica pomoću spojeva

Tablica Zaposlenici, odjeli, lokacije, zemlje, regije. Dobijte popis regija i broj zaposlenih u svakoj regiji
odluka

  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;

Tablica Zaposlenici, odjeli, lokacije, zemlje, regije. Dobijte detaljne informacije o svakom zaposleniku:
Ime, Prezime, Odjel, Posao, Ulica, Država, Regija
odluka

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);

Tablica zaposlenika. Prikaži sve menadžere koji imaju više od 6 zaposlenih
odluka

  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;

Tablica zaposlenika. Pokažite sve zaposlenike koji nikome ne odgovaraju
odluka

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;

Tablica zaposlenika, Job_history. Tablica zaposlenika pohranjuje sve zaposlenike. Tablica Job_history pohranjuje zaposlenike koji su napustili tvrtku. Dobijte izvještaj o svim zaposlenicima i njihovom statusu u tvrtki (Zaposleni ili napustili tvrtku s datumom odlaska)
Primjer:
ime | status
jennifer | Napustio tvrtku 31. prosinca 2006. godine
Klara | Trenutno radim
odluka

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);

Tablica Zaposlenici, odjeli, lokacije, zemlje, regije. Dobijte popis zaposlenika koji žive u Europi (region_name)
odluka

 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';

Tablica Zaposlenici, odjeli. Prikaži sve odjele s više od 30 zaposlenika
odluka

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

Tablica Zaposlenici, odjeli. Pokažite sve zaposlenike koji nisu ni u jednom odjelu
odluka

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;

Tablica Zaposlenici, odjeli. Prikaži sve odjele bez zaposlenih
odluka

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

Tablica zaposlenika. Prikaži sve zaposlenike koji nemaju podređene
odluka

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

Tablica Zaposlenici, poslovi, odjeli. Prikaži zaposlenike u formatu: Ime_ime, Naziv_posla, Naziv_odjela.
Primjer:
ime | naziv posla | Naziv_odjela
Donald | otprema | Službenik otpremni
odluka

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);

Tablica zaposlenika. Nabavite popis zaposlenika čiji su se menadžeri zaposlili 2005. godine, ali su istovremeno ti radnici sami dobili posao prije 2005. godine
odluka

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');

Tablica zaposlenika. Nabavite popis zaposlenika čiji su menadžeri dobili posao u mjesecu siječnju bilo koje godine, a duljina naziva naziva tih zaposlenika je veća od 15 znakova
odluka

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;

Korištenje podupita za rješavanje upita

Tablica zaposlenika. Dobijte popis zaposlenika s najdužim imenom.
odluka

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

Tablica zaposlenika. Dobijte popis zaposlenika s plaćom većom od prosječne plaće svih zaposlenika.
odluka

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

Tablica Zaposlenici, odjeli, lokacije. Dobijte grad u kojem zaposlenici ukupno zarađuju najmanje.
odluka

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);

Tablica zaposlenika. Dobijte popis zaposlenika čiji menadžer prima plaću veću od 15000.
odluka

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

Tablica Zaposlenici, odjeli. Prikaži sve odjele bez zaposlenih
odluka

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

Tablica zaposlenika. Prikaži sve zaposlenike koji nisu menadžeri
odluka

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

Tablica zaposlenika. Prikaži sve menadžere koji imaju više od 6 zaposlenih
odluka

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

Tablica Zaposlenici, Odjeli. Pokažite zaposlenike koji rade u IT odjelu
odluka

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

Tablica Zaposlenici, poslovi, odjeli. Prikaži zaposlenike u formatu: Ime_ime, Naziv_posla, Naziv_odjela.
Primjer:
ime | naziv posla | Naziv_odjela
Donald | otprema | Službenik otpremni
odluka

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;

Tablica zaposlenika. Nabavite popis zaposlenika čiji su se menadžeri zaposlili 2005. godine, ali su istovremeno ti radnici sami dobili posao prije 2005. godine
odluka

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');

Tablica zaposlenika. Nabavite popis zaposlenika čiji su menadžeri dobili posao u mjesecu siječnju bilo koje godine, a duljina naziva naziva tih zaposlenika je veća od 15 znakova
odluka

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;

To je sve za sada.

Nadam se da su zadaci bili zanimljivi i uzbudljivi.
Nadopunit ću ovaj popis što je više moguće.
Bit će mi drago i svim komentarima i prijedlozima.

PS: Ako netko smisli zanimljiv zadatak na SELECT-u, napišite u komentarima, dodat ću ga na popis.

Hvala Vam.

Izvor: www.habr.com

Dodajte komentar