Zdravo Habr!
Više od 3 godine predajem SQL u raznim trening centrima, a jedno od mojih zapažanja je da studenti bolje vladaju i razumiju SQL ako dobiju zadatak, a ne samo da pričaju o mogućnostima i teorijskim osnovama.
U ovom članku podijelit ću s vama svoju listu zadataka koje zadajem učenicima kao domaći zadatak i na kojima provodimo razne vrste brainstorminga, što dovodi do dubokog i jasnog razumijevanja SQL-a.
SQL (ˈɛsˈkjuˈɛl; eng. strukturirani jezik upita) je deklarativni programski jezik koji se koristi za kreiranje, modificiranje i upravljanje podacima u relacijskoj bazi podataka kojom upravlja odgovarajući sistem za upravljanje bazom podataka.
O SQL-u možete čitati iz različitih
Ovaj članak nije namijenjen da vas nauči SQL od nule.
Pa idemo.
Koristićemo dobro poznato
Napominjem da ćemo razmatrati samo zadatke na SELECT. Na DML-u i DDL-u nema zadataka.
zadaci
Ograničavanje i sortiranje podataka
Tabela zaposlenih. Dobijte listu sa informacijama o svim zaposlenima
odluka
SELECT * FROM employees
Tabela zaposlenih. Nabavite listu svih zaposlenih po imenu 'David'
odluka
SELECT *
FROM employees
WHERE first_name = 'David';
Tabela zaposlenih. Nabavite listu svih zaposlenih sa job_id jednakim 'IT_PROG'
odluka
SELECT *
FROM employees
WHERE job_id = 'IT_PROG'
Tabela zaposlenih. Dobijte spisak svih zaposlenih iz 50. odjeljenja (department_id) sa platom (platom) većom od 4000
odluka
SELECT *
FROM employees
WHERE department_id = 50 AND salary > 4000;
Tabela zaposlenih. Dobijte spisak svih zaposlenih iz 20. i iz 30. odjeljenja (department_id)
odluka
SELECT *
FROM employees
WHERE department_id = 20 OR department_id = 30;
Tabela zaposlenih. Dobijte listu svih zaposlenih čije je posljednje slovo u imenu 'a'
odluka
SELECT *
FROM employees
WHERE first_name LIKE '%a';
Tabela zaposlenih. Dobijte listu svih zaposlenih iz 50. i iz 80. odjela (department_id) koji imaju bonus (vrijednost u stupcu Commission_pct nije prazna)
odluka
SELECT *
FROM employees
WHERE (department_id = 50 OR department_id = 80)
AND commission_pct IS NOT NULL;
Tabela zaposlenih. Dobijte listu svih zaposlenih čije ime sadrži najmanje 2 slova 'n'
odluka
SELECT *
FROM employees
WHERE first_name LIKE '%n%n%';
Tabela zaposlenih. Dobijte listu svih zaposlenih čije je ime duže od 4 slova
odluka
SELECT *
FROM employees
WHERE first_name LIKE '%_____%';
Tabela zaposlenih. Dobijte listu svih zaposlenih čija je plata između 8000 i 9000 (uključivo)
odluka
SELECT *
FROM employees
WHERE salary BETWEEN 8000 AND 9000;
Tabela zaposlenih. Dobijte listu svih zaposlenih čije ime sadrži simbol '%'
odluka
SELECT *
FROM employees
WHERE first_name LIKE '%%%' ESCAPE '';
Tabela zaposlenih. Dobijte listu svih ID-ova menadžera
odluka
SELECT DISTINCT manager_id
FROM employees
WHERE manager_id IS NOT NULL;
Tabela zaposlenih. Dobijte listu zaposlenih sa njihovim pozicijama u formatu: Donald(sh_clerk)
odluka
SELECT first_name || '(' || LOWER (job_id) || ')' employee FROM employees;
Upotreba jednorednih funkcija za prilagođavanje izlaza
Tabela zaposlenih. Dobijte listu svih zaposlenih čije je ime duže od 10 slova
odluka
SELECT *
FROM employees
WHERE LENGTH (first_name) > 10;
Tabela zaposlenih. Dobijte listu svih zaposlenih koji imaju slovo 'b' u svom imenu (neosjetljivo na velika i mala slova)
odluka
SELECT *
FROM employees
WHERE INSTR (LOWER (first_name), 'b') > 0;
Tabela zaposlenih. Dobijte listu svih zaposlenih čije ime sadrži najmanje 2 slova 'a'
odluka
SELECT *
FROM employees
WHERE INSTR (LOWER (first_name),'a',1,2) > 0;
Tabela zaposlenih. Dobijte listu svih zaposlenih čija je plata višestruka od 1000
odluka
SELECT *
FROM employees
WHERE MOD (salary, 1000) = 0;
Tabela zaposlenih. Dobijte prvi trocifreni broj telefona zaposlenog 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. Uzmite prvu riječ iz naziva odjela za one koji imaju više od jedne riječi u imenu
odluka
SELECT department_name,
SUBSTR (department_name, 1, INSTR (department_name, ' ')-1)
first_word
FROM departments
WHERE INSTR (department_name, ' ') > 0;
Tabela zaposlenih. Dobijte imena zaposlenih bez prvog i posljednjeg slova u imenu
odluka
SELECT first_name, SUBSTR (first_name, 2, LENGTH (first_name) - 2) new_name
FROM employees;
Tabela zaposlenih. Dobijte listu svih zaposlenih čije je posljednje slovo u imenu jednako 'm' i dužina imena je veća od 5
odluka
SELECT *
FROM employees
WHERE SUBSTR (first_name, -1) = 'm' AND LENGTH(first_name)>5;
Dual table. Dobijte datum za sljedeći petak
odluka
SELECT NEXT_DAY (SYSDATE, 'FRIDAY') next_friday FROM DUAL;
Tabela zaposlenih. Dobijte listu svih zaposlenih koji su u kompaniji više od 17 godina
odluka
SELECT *
FROM employees
WHERE MONTHS_BETWEEN (SYSDATE, hire_date) / 12 > 17;
Tabela zaposlenih. Dobijte listu svih zaposlenih čija je zadnja cifra telefonskog broja neparna i sastoji se od 3 broja odvojena tačkom
odluka
SELECT *
FROM employees
WHERE MOD (SUBSTR (phone_number, -1), 2) != 0
AND INSTR (phone_number,'.',1,3) = 0;
Tabela zaposlenih. Dobijte listu svih zaposlenih čija vrijednost job_id iza znaka '_' ima najmanje 3 znaka, ali ova vrijednost iza '_' 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';
Tabela zaposlenih. Dobijte listu svih zaposlenih zamjenom svih '.' u vrijednosti PHONE_NUMBER na '-'
odluka
SELECT phone_number, REPLACE (phone_number, '.', '-') new_phone_number
FROM employees;
Korištenje funkcija konverzije i uvjetnih izraza
Tabela zaposlenih. Dobijte spisak svih zaposlenih koji su došli na posao prvog dana u mjesecu (bilo koji)
odluka
SELECT *
FROM employees
WHERE TO_CHAR (hire_date, 'DD') = '01';
Tabela zaposlenih. Dobijte spisak svih zaposlenih koji su došli na posao 2008. godine
odluka
SELECT *
FROM employees
WHERE TO_CHAR (hire_date, 'YYYY') = '2008';
DUAL table. Prikaži sutrašnji datum u formatu: Sutra je drugi dan januara
odluka
SELECT TO_CHAR (SYSDATE, 'fm""Tomorrow is ""Ddspth ""day of"" Month') info
FROM DUAL;
Tabela zaposlenih. Dobijte listu svih zaposlenih i datum njihovog početka u formatu: 21
odluka
SELECT first_name, TO_CHAR (hire_date, 'fmddth ""of"" Month, YYYY') hire_date
FROM employees;
Tabela zaposlenih. Dobijte spisak zaposlenih sa uvećanim platama za 20%. Prikaži platu sa znakom dolara
odluka
SELECT first_name, TO_CHAR (salary + salary * 0.20, 'fm$999,999.00') new_salary
FROM employees;
Tabela zaposlenih. Dobijte spisak svih zaposlenih koji su došli na posao u februaru 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 table. Izvezi trenutni datum, + 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;
Tabela zaposlenih. Dobijte listu svih zaposlenih sa punim platama (plata + 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;
Tabela zaposlenih. Dobijte listu svih zaposlenih i informacije o dostupnosti bonusa na platu (Da/Ne)
odluka
SELECT first_name, commission_pct, NVL2 (commission_pct, 'Yes', 'No') has_bonus
FROM employees;
Tabela zaposlenih. Dobijte nivo plate svakog zaposlenog: Manje od 5000 se smatra niskim nivoom, Većim ili jednakim 5000, a manjim od 10000 smatra se normalnim nivoom, Većim ili jednakim 10000 smatra se visokim nivoom
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;
Tabela zemalja. Za svaku zemlju pokažite region u kojem se nalazi: 1-Evropa, 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 korištenjem funkcija grupe
Tabela zaposlenih. Dobijte izvještaj po department_id sa minimalnom i maksimalnom platom, datumima ranog i kasnog dolaska i brojem zaposlenih. 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;
Tabela zaposlenih. Koliko zaposlenih čija imena počinju na isto slovo? Sortiraj po količini. Prikaži samo one u kojima 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;
Tabela zaposlenih. Koliko zaposlenih radi u istom odjelu i prima istu platu?
odluka
SELECT department_id, salary, COUNT (*)
FROM employees
GROUP BY department_id, salary
HAVING COUNT (*) > 1;
Tabela zaposlenih. Dobijte izvještaj o tome koliko je zaposlenih bilo zaposleno svakog dana u sedmici. Sortiraj 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;
Tabela zaposlenih. Dobijte izvještaj o tome koliko je zaposlenika zaposleno po godinama. Sortiraj po količini
odluka
SELECT TO_CHAR (hire_date, 'YYYY') year, COUNT (*)
FROM employees
GROUP BY TO_CHAR (hire_date, 'YYYY');
Tabela zaposlenih. Dobijte broj odjela koji imaju zaposlene
odluka
SELECT COUNT (COUNT (*)) department_count
FROM employees
WHERE department_id IS NOT NULL
GROUP BY department_id;
Tabela zaposlenih. Dobijte listu department_id sa više od 30 zaposlenih
odluka
SELECT department_id
FROM employees
GROUP BY department_id
HAVING COUNT (*) > 30;
Tabela zaposlenih. Dobijte listu department_ids i zaokruženu prosječnu platu zaposlenih u svakom odjelu.
odluka
SELECT department_id, ROUND (AVG (salary)) avg_salary
FROM employees
GROUP BY department_id;
Tabela zemalja. Dobijte listu region_id zbroja svih slova svih country_names u kojima je više od 60
odluka
SELECT region_id
FROM countries
GROUP BY region_id
HAVING SUM (LENGTH (country_name)) > 60;
Tabela zaposlenih. Dobijte listu department_id u kojoj rade zaposlenici nekoliko (>1) job_id
odluka
SELECT department_id
FROM employees
GROUP BY department_id
HAVING COUNT (DISTINCT job_id) > 1;
Tabela zaposlenih. Dobijte listu manager_id čiji je broj podređenih veći od 5 i zbir svih plata njegovih podređenih je veći od 50000
odluka
SELECT manager_id
FROM employees
GROUP BY manager_id
HAVING COUNT (*) > 5 AND SUM (salary) > 50000;
Tabela zaposlenih. Dobijte listu manager_id čija je prosječna plata 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;
Tabela zaposlenih. Dobijte maksimalnu platu od svih zaposlenih job_id koji se završava riječju 'SLOVNIK'
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';
Tabela zaposlenih. Dobijte maksimalnu platu među svim prosječnim platama za odjel
odluka
SELECT MAX (AVG (salary))
FROM employees
GROUP BY department_id;
Tabela zaposlenih. Dobijte broj zaposlenih sa istim brojem slova u svom imenu. Istovremeno, prikazati samo one čije je ime duže od 5 i broj zaposlenih sa istim imenom je veći od 20. Sortiraj 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 tabela pomoću spojeva
Tablični zaposleni, odjeli, lokacije, zemlje, regije. Dobijte listu 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;
Tablični zaposleni, odjeli, lokacije, zemlje, regije. Dobijte detaljne informacije o svakom zaposlenom:
Ime, Prezime, Odjel, Posao, Ulica, Država, Region
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);
Tabela zaposlenih. 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;
Tabela zaposlenih. Prikaži sve zaposlene 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;
Tabela zaposlenih, Job_history. Tabela Employee pohranjuje sve zaposlene. Tabela Job_history pohranjuje zaposlenike koji su napustili kompaniju. Dobijte izvještaj o svim zaposlenima i njihovom statusu u kompaniji (zaposleni ili napustili kompaniju sa datumom odlaska)
Primjer:
ime | status
jennifer | Napustio je kompaniju 31. decembra 2006
Clara | Trenutno radi
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);
Tablični zaposleni, odjeli, lokacije, zemlje, regije. Dobijte listu zaposlenih koji žive u Evropi (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';
Stolni zaposleni, odjeli. Prikaži sve odjele s više od 30 zaposlenih
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;
Stolni zaposleni, odjeli. Prikaži sve zaposlene koji nisu ni u jednom odjeljenju
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;
Stolni zaposleni, 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;
Tabela zaposlenih. Prikaži sve zaposlene 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;
Stolni zaposleni, poslovi, odjeli. Prikažite zaposlene u formatu: Ime_ime, Naziv_posla, Ime_odjela.
Primjer:
ime | naziv radnog mjesta | Department_name
Donald | otprema | Clerk Shipping
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);
Tabela zaposlenih. Dobijte spisak zaposlenih čiji su se rukovodioci zaposlili 2005. godine, ali su u isto vrijeme i sami ovi radnici dobili posao prije 2005.
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');
Tabela zaposlenih. Dobijte listu zaposlenika čiji su menadžeri dobili posao u mjesecu januaru bilo koje godine i dužina posla_title ovih zaposlenika je više 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 potupita za rješavanje upita
Tabela zaposlenih. Dobijte listu zaposlenih sa najdužim imenom.
odluka
SELECT *
FROM employees
WHERE LENGTH (first_name) =
(SELECT MAX (LENGTH (first_name)) FROM employees);
Tabela zaposlenih. Dobijte listu zaposlenih sa platom većom od prosečne plate svih zaposlenih.
odluka
SELECT *
FROM employees
WHERE salary > (SELECT AVG (salary) FROM employees);
Stolni zaposleni, odjeli, lokacije. Dobijte grad u kojem zaposleni 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);
Tabela zaposlenih. Dobijte listu zaposlenih čiji menadžer prima platu veću od 15000.
odluka
SELECT *
FROM employees
WHERE manager_id IN (SELECT employee_id
FROM employees
WHERE salary > 15000)
Stolni zaposleni, 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);
Tabela zaposlenih. Prikaži sve zaposlene koji nisu menadžeri
odluka
SELECT *
FROM employees
WHERE employee_id NOT IN (SELECT manager_id
FROM employees
WHERE manager_id IS NOT NULL)
Tabela zaposlenih. 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;
Stolni zaposleni, odjeli. Pokažite zaposlene koji rade u IT odjelu
odluka
SELECT *
FROM employees
WHERE department_id = (SELECT department_id
FROM departments
WHERE department_name = 'IT');
Stolni zaposleni, poslovi, odjeli. Prikažite zaposlene u formatu: Ime_ime, Naziv_posla, Ime_odjela.
Primjer:
ime | naziv radnog mjesta | Department_name
Donald | otprema | Clerk Shipping
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;
Tabela zaposlenih. Dobijte spisak zaposlenih čiji su se rukovodioci zaposlili 2005. godine, ali su u isto vrijeme i sami ovi radnici dobili posao prije 2005.
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');
Tabela zaposlenih. Dobijte listu zaposlenika čiji su menadžeri dobili posao u mjesecu januaru bilo koje godine i dužina posla_title ovih zaposlenika je više 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.
Dodaću na ovu listu što je više moguće.
Također će mi biti drago svim komentarima i sugestijama.
PS: Ako neko smisli neki interesantan zadatak na SELECT, napišite u komentarima, dodaću ga na listu.
Spasibo.
izvor: www.habr.com