SQL. Займальныя задачы

Добры дзень, Хабр!

Вось ужо больш за 3 гады я выкладаю SQL у розных трэнінг цэнтрах, і адным з маіх назіранняў з'яўляецца тое, што студэнты асвойваюць і разумеюць SQL лепш, калі ставіць перад імі задачу, а не проста распавядаць аб магчымасцях і тэарэтычных асновах.

У гэтым артыкуле я падзялюся з вамі сваім спісам задач, якія я даю студэнтам у якасці хатняга задання і над якімі мы праводзім рознага роду брэйнстормы, што прыводзіць да глыбокага і выразнага разумення SQL.

SQL. Займальныя задачы

SQL (ˈɛsˈkjuˈɛl; англ. structured query language — «мова структураваных запытаў») — дэкларатыўная мова праграмавання, якая ўжываецца для стварэння, мадыфікацыі і кіравання дадзенымі ў рэляцыйнай базе дадзеных, якая кіруецца адпаведнай сістэмай кіравання базамі дадзеных. Больш падрабязна ...

Пачытаць пра SQL можна з розных крыніц.
Дадзены артыкул не мае на мэце навучыць вас SQL з нуля.

Такім чынам, паехалі.

Будзем выкарыстоўваць усім вядомую схему HR у Oracle з яе табліцамі (Больш падрабязна):

SQL. Займальныя задачы
Адзначу, што мы будзем разглядаць толькі задачы на ​​SELECT. Тут няма задач на DML і DDL.

задачы

Restricting and Sorting Data

Табліца Employees. Атрымаць спіс з інфармацыяй аб усіх супрацоўніках
рашэнне

SELECT * FROM employees

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў з імем 'David'
рашэнне

SELECT *
  FROM employees
 WHERE first_name = 'David';

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў з job_id роўным 'IT_PROG'
рашэнне

SELECT *
  FROM employees
 WHERE job_id = 'IT_PROG'

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў з 50-га аддзела (department_id) з заробкам(salary), большым за 4000
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў з 20-га і з 30-га аддзела (department_id)
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх апошняя літара ў імі роўная 'a'
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў з 50-га і з 80-га аддзела (department_id) у якіх ёсць бонус (значэнне ў калонцы commission_pct не пустое)
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх у імені змяшчаюцца мінімум 2 літары 'n'
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх даўжыня імя больш за 4 літары.
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх заробак знаходзіцца ў прамежку ад 8000 да 9000 (уключна)
рашэнне

SELECT *
  FROM employees
 WHERE salary BETWEEN 8000 AND 9000;

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх у імені змяшчаецца сімвал '%'
рашэнне

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

Табліца Employees. Атрымаць спіс усіх ID мэнэджэраў
рашэнне

SELECT DISTINCT manager_id
  FROM employees
 WHERE manager_id IS NOT NULL;

Табліца Employees. Атрымаць спіс работнікаў з іх пазіцыямі ў фармаце: Donald(sh_clerk)
рашэнне

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

Using Single-Row Functions to Customize Output

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх даўжыня імя больш за 10 літары.
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх у імені ёсць літара 'b' (без уліку рэгістра)
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх у імені змяшчаюцца мінімум 2 літары 'a'
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў заробак якіх кратны 1000
рашэнне

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

Табліца Employees. Атрымаць першы 3х значны лік тэлефоннага нумара супрацоўніка калі яго нумар у фармаце ХХХ.ХХХ.ХХХХ
рашэнне

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

Табліца Departments. Атрымаць першае слова з імя дэпартамента для тых у каго ў назве больш за адно слова
рашэнне

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

Табліца Employees. Атрымаць імёны супрацоўнікаў без першай і апошняй літары ў імені
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх апошняя літара ў імі роўная 'm' і доўгай імя большай 5ти
рашэнне

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

Табліца Dual. Атрымаць дату наступнай пятніцы
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў якія працуюць у кампаніі больш за 17 гадоў
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх апошняя лічба тэлефоннага нумара няцотная і складаецца з 3 лікаў падзеленых кропкай
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў у якіх у значэнні job_id пасля знака '_' прынамсі 3 знака але пры гэтым гэтае значэнне пасля '_' не роўна 'CLERK'
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў замяніўшы ў значэнні PHONE_NUMBER усё '.' на '-'
рашэнне

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

Using Conversion Functions and Conditional Expressions

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў, якія прыйшлі на працу ў першы дзень месяца (любога)
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў, якія прыйшлі на працу ў 2008 годзе.
рашэнне

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

Табліца DUAL. Паказаць заўтрашнюю дату ў фармаце: Tomorrow is Second day of January
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў і дату прыходу на працу кожнага ў фармаце: 21st of June, 2007
рашэнне

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

Табліца Employees. Атрымаць спіс работнікаў з павялічанымі заробкамі на 20%. Зарплату паказаць са знакам даляра
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў якія прышылі на працу ў лютым 2007-га года.
рашэнне

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. Вывезці актуальную дату, + секунда, + хвіліна, + гадзіна, + дзень, + месяц, + год
рашэнне

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;

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў з поўнымі заробкамі (salary + commission_pct(%)) у фармаце: $24,000.00
рашэнне

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

Табліца Employees. Атрымаць спіс усіх супрацоўнікаў і інфармацыю аб наяўнасці бонусаў да заробку (Yes/No)
рашэнне

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

Табліца Employees. Атрымаць узровень зарплаты кожнага супрацоўніка: Менш 5000 лічыцца Low level, Больш ці роўна 5000 і менш 10000 лічыцца Normal level, Больш иои роўна 10000 лічыцца High level
рашэнне

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;

Табліца Countries. Для кожнай краіны паказаць рэгіён у якім ён знаходзіцца: 1-Europe, 2-America, 3-Asia, 4-Africa (без Join)
рашэнне

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 Aggregated Data Using the Group Functions

Табліца Employees. Атрымаць рэпарт па department_id з мінімальным і максімальным заробкам, з ранняй і позняй датай прыходу на працу і з колькасцю супрацоўнікаў. Сарыраваць па колькасці супрацоўнікаў (па змяншэнні)
рашэнне

  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;

Табліца Employees. Колькі супрацоўнікаў імёны якіх пачынаецца з адной і той жа літары? Сартаваць па колькасці. Паказваць толькі тыя дзе колькасць большая за 1
рашэнне

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;

Табліца Employees. Колькі супрацоўнікаў якія працуюць у адным і таксама аддзеле і атрымліваюць аднолькавую зарплату?
рашэнне

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

Табліца Employees. Атрымаць рэпарт колькі супрацоўнікаў прынялі на працу ў кожны дзень тыдня. Сартаваць па колькасці
рашэнне

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

Табліца Employees. Атрымаць рэпарт колькі супрацоўнікаў прынялі на працу па гадах. Сартаваць па колькасці
рашэнне

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

Табліца Employees. Атрымаць колькасць дэпартаментаў у якім ёсць супрацоўнікі
рашэнне

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

Табліца Employees. Атрымаць спіс department_id у якім працуюць больш за 30 супрацоўнікаў
рашэнне

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

Табліца Employees. Атрымаць спіс department_id і акругленую сярэднюю зарплату работнікаў у кожным дэпартаменце.
рашэнне

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

Табліца Countries. Атрымаць спіс region_id сума ўсіх літар усіх country_name у якім больш 60ти
рашэнне

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

Табліца Employees. Атрымаць спіс department_id у якім працуюць працаўнікі некалькіх (>1) job_id
рашэнне

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

Табліца Employees. Атрымаць спіс manager_id у якіх колькасць падпарадкаваных больш за 5 і сума ўсіх заробкаў яго падпарадкаваных больш за 50000
рашэнне

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

Табліца Employees. Атрымаць спіс manager_id у якіх сярэдні заробак усіх яго падначаленых знаходзіцца ў прамежку ад 6000 да 9000 якія не атрымліваюць бонусы (commission_pct пусты)
рашэнне

  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;

Табліца Employees. Атрымаць максімальную зарплату з усіх супрацоўнікаў job_id, які заканчваецца на слова 'CLERK'
рашэнне

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

Табліца Employees. Атрымаць максімальную зарплату сярод усіх сярэдніх заробкаў па дэпартаменце
рашэнне

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

Табліца Employees. Атрымаць колькасць супрацоўнікаў з аднолькавай колькасцю літар у імені. Пры гэтым паказаць толькі тых у каго даўжыня імя больш за 5 і колькасць супрацоўнікаў з такім імем больш за 20. Сартаваць па даўжыні імя
рашэнне

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

Displaying Data from Multiple Tables Using Joins

Табліца Employees, Departaments, Locations, Countries, Regions. Атрымаць спіс рэгіёнаў і колькасць супрацоўнікаў у кожным рэгіёне
рашэнне

  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;

Табліца Employees, Departaments, Locations, Countries, Regions. Атрымаць дэталёвую інфармацыю аб кожным супрацоўніку:
First_name, Last_name, Departamento, Job, Street, Country, Region
рашэнне

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

Табліца Employees. Паказаць усіх менеджэраў, якія маюць у падпарадкаванні больш за 6 супрацоўнікаў
рашэнне

  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;

Табліца Employees. Паказаць усіх супрацоўнікаў, якія ні каму не падпарадкоўваюцца
рашэнне

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;

Табліца Employees, Job_history. У табліцы Employee захоўваюцца ўсе супрацоўнікі. У табліцы Job_history захоўваюцца супрацоўнікі, якія пакінулі кампанію. Атрымаць рэпарт аб усіх супрацоўніках і аб яго статусе ў кампаніі (Працуе ці пакінуў кампанію з датай догляду)
Прыклад:
first_name | status
Jennifer | Left the company at 31 of December, 2006
Clara | Currently Working
рашэнне

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

Табліца Employees, Departaments, Locations, Countries, Regions. Атрымаць спіс супрацоўнікаў, якія жывуць у Europe (region_name)
рашэнне

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

Табліца Employees, Departaments. Паказаць усе дэпартаменты ў якіх працуюць больш за 30 супрацоўнікаў
рашэнне

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

Табліца Employees, Departaments. Паказаць усіх супрацоўнікаў якія не складаюцца ні ў адным дэпартаменце
рашэнне

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;

Табліца Employees, Departaments. Паказаць усе дэпартаменты ў якіх няма ніводнага супрацоўніка
рашэнне

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

Табліца Employees. Паказаць усіх супрацоўнікаў у якіх няма ні каго ў падпарадкаванні
рашэнне

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

Табліца Employees, Jobs, Departaments. Паказаць супрацоўнікаў у фармаце: First_name, Job_title, Department_name.
Прыклад:
First_name | Job_title | Department_name
Donald | Shipping | Clerk Shipping
рашэнне

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

Табліца Employees. Атрымаць спіс супрацоўнікаў менеджэры якіх уладкаваліся на працу ў 2005 годзе, але пры гэтым самі гэтыя работнікі ўладкаваліся на працу да 2005 года.
рашэнне

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

Табліца Employees. Атрымаць спіс супрацоўнікаў менеджэры якіх уладкаваліся на працу ў студзені месяцы любога года і даўжыня job_title гэтых супрацоўнікаў больш за 15 знакаў
рашэнне

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;

Using Subqueries to Solve Queries

Табліца Employees. Атрымаць спіс супрацоўнікаў з самым доўгім імем.
рашэнне

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

Табліца Employees. Атрымаць спіс супрацоўнікаў з заробкам большага за сярэдні заробак усіх супрацоўнікаў.
рашэнне

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

Табліца Employees, Departments, Locations. Атрымаць горад у якім супрацоўнікі ў суме зарабляюць менш за ўсіх.
рашэнне

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

Табліца Employees. Атрымаць спіс супрацоўнікаў у якіх менеджэр атрымлівае заробак больш за 15000.
рашэнне

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

Табліца Employees, Departaments. Паказаць усе дэпартаменты ў якіх няма ніводнага супрацоўніка
рашэнне

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

Табліца Employees. Паказаць усіх супрацоўнікаў якія не з'яўляюцца мэнэджэрамі
рашэнне

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

Табліца Employees. Паказаць усіх менеджэраў, якія маюць у падпарадкаванні больш за 6 супрацоўнікаў
рашэнне

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

Табліца Employees, Departaments. Паказаць супрацоўнікаў, якія працуюць у дэпартаменце IT
рашэнне

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

Табліца Employees, Jobs, Departaments. Паказаць супрацоўнікаў у фармаце: First_name, Job_title, Department_name.
Прыклад:
First_name | Job_title | Department_name
Donald | Shipping | Clerk Shipping
рашэнне

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;

Табліца Employees. Атрымаць спіс супрацоўнікаў менеджэры якіх уладкаваліся на працу ў 2005 годзе, але пры гэтым самі гэтыя работнікі ўладкаваліся на працу да 2005 года.
рашэнне

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

Табліца Employees. Атрымаць спіс супрацоўнікаў менеджэры якіх уладкаваліся на працу ў студзені месяцы любога года і даўжыня job_title гэтых супрацоўнікаў больш за 15 знакаў
рашэнне

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;

На гэтым пакуль усё.

Спадзяюся, задачы былі цікавымі і займальнымі.
Буду па магчымасці дапаўняць гэты спіс задач.
Таксама буду рады любым заўвагам і прапановам.

PS: Калі камусьці ў галаву прыйдзе цікавая задача на SELECT, пішыце ў каментарах, дадам у спіс.

Дзякуй.

Крыніца: habr.com

Дадаць каментар