SQL. Zábavné hádanky

Ahoj Habr!

Více než 3 roky učím SQL v různých školicích střediscích a jedním z mých postřehů je, že studenti SQL lépe ovládají a rozumějí mu, pokud dostanou úkol, a ne jen mluvit o možnostech a teoretických základech.

V tomto článku se s vámi podělím o svůj seznam úkolů, které zadávám studentům jako domácí úkol a na kterých vedeme různé druhy brainstormů, což vede k hlubokému a jasnému pochopení SQL.

SQL. Zábavné hádanky

SQL (ˈɛsˈkjuˈɛl; eng. strukturovaný dotazovací jazyk) je deklarativní programovací jazyk používaný k vytváření, úpravě a správě dat v relační databázi spravované vhodným systémem pro správu databází. Více informací ...

O SQL si můžete přečíst od různých Zdroje.
Účelem tohoto článku není naučit vás SQL od nuly.

Tak pojďme.

Použijeme známé HR schéma v Oracle s jeho tabulkami (více):

SQL. Zábavné hádanky
Podotýkám, že budeme uvažovat pouze úkoly na SELECT. Na DML a DDL nejsou žádné úkoly.

úkoly

Omezení a třídění dat

Tabulka zaměstnanců. Získejte seznam s informacemi o všech zaměstnancích
rozhodnutí

SELECT * FROM employees

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců s názvem 'David'
rozhodnutí

SELECT *
  FROM employees
 WHERE first_name = 'David';

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců s job_id rovným 'IT_PROG'
rozhodnutí

SELECT *
  FROM employees
 WHERE job_id = 'IT_PROG'

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců z 50. oddělení (department_id) s platem (platem) vyšším než 4000
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců z 20. a z 30. oddělení (department_id)
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž poslední písmeno v jejich jméně je „a“
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců z 50. a z 80. oddělení (department_id), kteří mají bonus (hodnota ve sloupci Commission_pct není prázdná)
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž jméno obsahuje alespoň 2 písmena „n“
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž jméno je delší než 4 písmena
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž plat je mezi 8000 a 9000 (včetně)
rozhodnutí

SELECT *
  FROM employees
 WHERE salary BETWEEN 8000 AND 9000;

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž jméno obsahuje symbol '%'
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech ID manažerů
rozhodnutí

SELECT DISTINCT manager_id
  FROM employees
 WHERE manager_id IS NOT NULL;

Tabulka zaměstnanců. Získejte seznam zaměstnanců s jejich pozicemi ve formátu: Donald(sh_clerk)
rozhodnutí

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

Použití jednořádkových funkcí k přizpůsobení výstupu

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž jméno je delší než 10 písmena
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, kteří mají ve jméně písmeno „b“ (nerozlišují se malá a velká písmena)
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž jméno obsahuje alespoň 2 písmena „a“
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž plat je násobkem 1000
rozhodnutí

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

Tabulka zaměstnanců. Získejte první 3místné číslo telefonního čísla zaměstnance, pokud je jeho číslo ve formátu ХХХ.ХХХ.ХХХХ
rozhodnutí

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

Tabulka oddělení. Získejte první slovo z názvu oddělení pro ty, kteří mají v názvu více než jedno slovo
rozhodnutí

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

Tabulka zaměstnanců. Získejte jména zaměstnanců bez prvního a posledního písmene v názvu
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž poslední písmeno ve jméně se rovná 'm' a délka jména je větší než 5
rozhodnutí

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

Dvojitý stůl. Získejte datum příštího pátku
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, kteří jsou ve společnosti více než 17 let
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž poslední číslice telefonního čísla je lichá a skládá se ze 3 čísel oddělených tečkou
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, jejichž hodnota job_id za znaménkem '_' má alespoň 3 znaky, ale tato hodnota za '_' se nerovná 'CLERK'
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců nahrazením všech „.“ v hodnotě PHONE_NUMBER na '-'
rozhodnutí

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

Použití konverzních funkcí a podmíněných výrazů

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, kteří přišli do práce první den v měsíci (jakýkoli)
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, kteří přišli do práce v roce 2008
rozhodnutí

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

DUÁLNÍ stůl. Zobrazit zítřejší datum ve formátu: Zítra je druhý lednový den
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců a jejich datum nástupu ve formátu: 21. června 2007
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam zaměstnanců se zvýšenými platy o 20 %. Zobrazit plat znakem dolaru
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců, kteří přišli do práce v únoru 2007.
rozhodnutí

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

DUÁLNÍ stůl. Export aktuálního data, + sekundy, + minuty, + hodiny, + dne, + měsíce, + roku
rozhodnutí

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;

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců s plnými platy (plat + provize_pct(%)) ve formátu: 24,000.00 XNUMX $
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam všech zaměstnanců a informace o dostupnosti mzdových bonusů (Ano/Ne)
rozhodnutí

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

Tabulka zaměstnanců. Získejte platovou úroveň každého zaměstnance: Méně než 5000 5000 je považováno za nízkou úroveň, Větší než nebo rovno 10000 10000 a méně než XNUMX XNUMX je považováno za normální úroveň, Větší nebo rovné XNUMX XNUMX je považováno za vysokou úroveň
rozhodnutí

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;

Tabulka zemí. U každé země uveďte region, ve kterém se nachází: 1-Evropa, 2-Amerika, 3-Asie, 4-Afrika (bez připojení)
rozhodnutí

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;

Vykazování agregovaných dat pomocí skupinových funkcí

Tabulka zaměstnanců. Získejte zprávu podle department_id s minimálním a maximálním platem, datem předčasných a pozdních příchodů a počtem zaměstnanců. Seřadit podle počtu zaměstnanců (popis)
rozhodnutí

  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;

Tabulka zaměstnanců. Kolik zaměstnanců, jejichž jméno začíná stejným písmenem? Seřadit podle množství. Zobrazit pouze ty, kde je číslo větší než 1
rozhodnutí

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;

Tabulka zaměstnanců. Kolik zaměstnanců pracuje ve stejném oddělení a pobírá stejnou mzdu?
rozhodnutí

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

Tabulka zaměstnanců. Získejte přehled o tom, kolik zaměstnanců bylo přijato každý den v týdnu. Seřadit podle množství
rozhodnutí

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

Tabulka zaměstnanců. Získejte přehled o tom, kolik zaměstnanců bylo přijato za rok. Seřadit podle množství
rozhodnutí

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

Tabulka zaměstnanců. Získejte počet oddělení, která mají zaměstnance
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam department_id s více než 30 zaměstnanci
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam id_oddělení a zaokrouhlený průměrný plat zaměstnanců v každém oddělení.
rozhodnutí

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

Tabulka zemí. Získejte seznam region_id součet všech písmen všech názvů zemí, ve kterých je více než 60
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam department_id, ve kterém pracují zaměstnanci několika (>1) job_id
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam manager_id, jehož počet podřízených je větší než 5 a součet všech platů jeho podřízených je větší než 50000 XNUMX
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam manager_id, jehož průměrný plat všech jeho podřízených je mezi 6000 a 9000, kteří nedostávají bonusy (commission_pct je prázdný)
rozhodnutí

  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;

Tabulka zaměstnanců. Získejte maximální plat od všech zaměstnanců job_id, který končí slovem 'CLERK'
rozhodnutí

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

Tabulka zaměstnanců. Získejte maximální plat mezi všemi průměrnými platy za oddělení
rozhodnutí

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

Tabulka zaměstnanců. Získejte počet zaměstnanců se stejným počtem písmen ve jméně. Zároveň zobrazit pouze ty, jejichž jméno je delší než 5 a počet zaměstnanců se stejným jménem je vyšší než 20. Seřadit podle délky jména
rozhodnutí

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

Zobrazení dat z více tabulek pomocí spojení

Tabulka Zaměstnanci, Oddělení, Místa, Země, Regiony. Získejte seznam regionů a počet zaměstnanců v každém regionu
rozhodnutí

  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;

Tabulka Zaměstnanci, Oddělení, Místa, Země, Regiony. Získejte podrobné informace o každém zaměstnanci:
Jméno, Příjmení, Oddělení, Práce, Ulice, Země, Oblast
rozhodnutí

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

Tabulka zaměstnanců. Zobrazit všechny manažery, kteří mají více než 6 zaměstnanců
rozhodnutí

  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;

Tabulka zaměstnanců. Zobrazit všechny zaměstnance, kteří se nikomu nehlásí
rozhodnutí

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;

Tabulka zaměstnanců, Job_history. V tabulce Zaměstnanci jsou uloženi všichni zaměstnanci. Tabulka Job_history ukládá zaměstnance, kteří opustili společnost. Získejte přehled o všech zaměstnancích a jejich postavení ve společnosti (zaměstnáni nebo opustili společnost s datem odchodu)
Příklad:
křestní_jméno | postavení
jennifer | Ze společnosti odešel k 31. prosinci 2006
Klára | Právě pracující
rozhodnutí

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

Tabulka Zaměstnanci, Oddělení, Místa, Země, Regiony. Získejte seznam zaměstnanců, kteří žijí v Evropě (region_name)
rozhodnutí

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

Tabulka Zaměstnanci, Oddělení. Zobrazit všechna oddělení s více než 30 zaměstnanci
rozhodnutí

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

Tabulka Zaměstnanci, Oddělení. Zobrazit všechny zaměstnance, kteří nejsou v žádném oddělení
rozhodnutí

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;

Tabulka Zaměstnanci, Oddělení. Zobrazit všechna oddělení bez zaměstnanců
rozhodnutí

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

Tabulka zaměstnanců. Zobrazit všechny zaměstnance, kteří nemají žádné podřízené
rozhodnutí

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

Tabulka Zaměstnanci, Práce, Oddělení. Zobrazit zaměstnance ve formátu: Křestní_jméno, Pracovní_název, Název_oddělení.
Příklad:
křestní_jméno | pracovní pozice | Název_oddělení
Donald | doprava | Úředník přepravy
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam zaměstnanců, jejichž manažeři získali práci v roce 2005, ale zároveň tito pracovníci sami získali práci před rokem 2005
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam zaměstnanců, jejichž manažeři dostali práci v měsíci lednu kteréhokoli roku a délka job_title těchto zaměstnanců je delší než 15 znaků
rozhodnutí

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;

Použití poddotazů k řešení dotazů

Tabulka zaměstnanců. Získejte seznam zaměstnanců s nejdelším jménem.
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam zaměstnanců s platem vyšším, než je průměrný plat všech zaměstnanců.
rozhodnutí

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

Tabulka Zaměstnanci, Oddělení, Místa. Získejte město, ve kterém zaměstnanci vydělávají nejméně celkově.
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam zaměstnanců, jejichž manažer pobírá plat vyšší než 15000 XNUMX.
rozhodnutí

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

Tabulka Zaměstnanci, Oddělení. Zobrazit všechna oddělení bez zaměstnanců
rozhodnutí

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

Tabulka zaměstnanců. Zobrazit všechny zaměstnance, kteří nejsou manažery
rozhodnutí

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

Tabulka zaměstnanců. Zobrazit všechny manažery, kteří mají více než 6 zaměstnanců
rozhodnutí

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

Tabulka Zaměstnanci, Oddělení. Ukažte zaměstnance, kteří pracují v IT oddělení
rozhodnutí

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

Tabulka Zaměstnanci, Práce, Oddělení. Zobrazit zaměstnance ve formátu: Křestní_jméno, Pracovní_název, Název_oddělení.
Příklad:
křestní_jméno | pracovní pozice | Název_oddělení
Donald | doprava | Úředník přepravy
rozhodnutí

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;

Tabulka zaměstnanců. Získejte seznam zaměstnanců, jejichž manažeři získali práci v roce 2005, ale zároveň tito pracovníci sami získali práci před rokem 2005
rozhodnutí

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

Tabulka zaměstnanců. Získejte seznam zaměstnanců, jejichž manažeři dostali práci v měsíci lednu kteréhokoli roku a délka job_title těchto zaměstnanců je delší než 15 znaků
rozhodnutí

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 prozatím vše.

Doufám, že úkoly byly zajímavé a napínavé.
Doplním tento seznam co nejvíce.
Budu také rád za jakékoli připomínky a návrhy.

PS: Pokud někoho napadne zajímavý úkol na SELECT, napište do komentářů, přidám ho do seznamu.

Děkuju.

Zdroj: www.habr.com

Přidat komentář