SQL. ื—ื™ื“ื•ืช ืžืฉืขืฉืขื•ืช

ืฉืœื•ื ื”ื‘ืจ!

ื›ื‘ืจ ื™ื•ืชืจ ืž-3 ืฉื ื™ื ืฉืื ื™ ืžืœืžื“ SQL ื‘ืžืจื›ื–ื™ ื”ื“ืจื›ื” ืฉื•ื ื™ื, ื•ืื—ืช ื”ืชืฆืคื™ื•ืช ืฉืœื™ ื”ื™ื ืฉืกื˜ื•ื“ื ื˜ื™ื ืฉื•ืœื˜ื™ื ื•ืžื‘ื™ื ื™ื ื˜ื•ื‘ ื™ื•ืชืจ ืืช SQL ืื ื ื•ืชื ื™ื ืœื”ื ืžืฉื™ืžื”, ื•ืœื ืจืง ืžื“ื‘ืจื™ื ืขืœ ื”ืืคืฉืจื•ื™ื•ืช ื•ื”ื™ืกื•ื“ื•ืช ื”ืชื™ืื•ืจื˜ื™ื™ื.

ื‘ืžืืžืจ ื–ื” ืืฉืชืฃ ืืชื›ื ื‘ืจืฉื™ืžืช ื”ืžืฉื™ืžื•ืช ืฉืœื™ ืฉืื ื™ ื ื•ืชืŸ ืœืชืœืžื™ื“ื™ื ื›ืฉื™ืขื•ืจื™ ื‘ื™ืช ื•ืขืœื™ื”ืŸ ืื ื• ืขื•ืจื›ื™ื ืกื™ืขื•ืจ ืžื•ื—ื•ืช ืžืกื•ื’ื™ื ืฉื•ื ื™ื, ืžื” ืฉืžื•ื‘ื™ืœ ืœื”ื‘ื ื” ืขืžื•ืงื” ื•ื‘ืจื•ืจื” ืฉืœ SQL.

SQL. ื—ื™ื“ื•ืช ืžืฉืขืฉืขื•ืช

SQL (หˆษ›sหˆkjuหˆษ›l; eng. structured query language) ื”ื™ื ืฉืคืช ืชื›ื ื•ืช ื”ืฆื”ืจืชื™ืช ื”ืžืฉืžืฉืช ืœื™ืฆื™ืจื”, ืฉื™ื ื•ื™ ื•ื ื™ื”ื•ืœ ืฉืœ ื ืชื•ื ื™ื ื‘ืžืกื“ ื ืชื•ื ื™ื ื™ื—ืกื™ ื”ืžื ื•ื”ืœ ืขืœ ื™ื“ื™ ืžืขืจื›ืช ื ื™ื”ื•ืœ ืžืกื“ ื ืชื•ื ื™ื ืžืชืื™ืžื”. ืงืจื ืขื•ื“ ...

ืืชื” ื™ื›ื•ืœ ืœืงืจื•ื ืขืœ SQL ืžืžื’ื•ื•ืŸ ืžืงื•ืจื•ืช.
ืžืืžืจ ื–ื” ืœื ื ื•ืขื“ ืœืœืžื“ ืื•ืชืš SQL ืžืืคืก.

ืื– ื‘ื•ืื• ื ืœืš.

ื ืฉืชืžืฉ ื‘ื™ื“ื•ืข ืชื›ื ื™ืช ืžืฉืื‘ื™ ืื ื•ืฉ ื‘ืื•ืจืงืœ ืขื ื”ืฉื•ืœื—ื ื•ืช ืฉืœื” (ืงืจื ืขื•ื“):

SQL. ื—ื™ื“ื•ืช ืžืฉืขืฉืขื•ืช
ืืฆื™ื™ืŸ ื›ื™ ื ืฉืงื•ืœ ืจืง ืžืฉื™ืžื•ืช ื‘-SELECT. ืื™ืŸ ืžืฉื™ืžื•ืช ื‘-DML ื•-DDL.

ืžืฉื™ืžื•ืช

ื”ื’ื‘ืœืช ื•ืžื™ื•ืŸ ื ืชื•ื ื™ื

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืขื ืžื™ื“ืข ืขืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื
ื”ื—ืœื˜ื”

SELECT * FROM employees

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ื‘ืฉื 'ื“ื•ื“'
ื”ื—ืœื˜ื”

SELECT *
  FROM employees
 WHERE first_name = 'David';

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืขื job_id ืฉื•ื•ื” ืœ-'IT_PROG'
ื”ื—ืœื˜ื”

SELECT *
  FROM employees
 WHERE job_id = 'IT_PROG'

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืžื”ืžื—ืœืงื” ื”-50 (ืžื–ื”ื”_ืžื—ืœืงื”) ืขื ืฉื›ืจ (ืฉื›ืจ) ื’ื‘ื•ื” ืž-4000
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืžื”ืžื—ืœืงื” ื”-20 ื•ืžื”ืžื—ืœืงื” ื”-30 (ืžื–ื”ื”_ืžื—ืœืงื”)
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉื”ืื•ืช ื”ืื—ืจื•ื ื” ื‘ืฉืžื ื”ื™ื 'a'
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืžื”ืžื—ืœืงื” ื”-50 ื•ืžื”ืžื—ืœืงื” ื”-80 (ืžื–ื”ื”_ืžื—ืœืงื”) ืฉื™ืฉ ืœื”ื ื‘ื•ื ื•ืก (ื”ืขืจืš ื‘ืขืžื•ื“ื” commission_pct ืื™ื ื• ืจื™ืง)
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืฉืžื ืžื›ื™ืœ ืœืคื—ื•ืช 2 ืื•ืชื™ื•ืช 'n'
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืฉืžื ืืจื•ืš ืž-4 ืื•ืชื™ื•ืช
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉื”ืฉื›ืจ ืฉืœื”ื ื”ื•ื ื‘ื™ืŸ 8000 ืœ-9000 (ื›ื•ืœืœ)
ื”ื—ืœื˜ื”

SELECT *
  FROM employees
 WHERE salary BETWEEN 8000 AND 9000;

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืฉืžื ืžื›ื™ืœ ืืช ื”ืกืžืœ '%'
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืจืฉื™ืžื” ืฉืœ ื›ืœ ืžื–ื”ื™ ื”ืžื ื”ืœื™ื
ื”ื—ืœื˜ื”

SELECT DISTINCT manager_id
  FROM employees
 WHERE manager_id IS NOT NULL;

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืขื•ื‘ื“ื™ื ืขื ืชืคืงื™ื“ื™ื”ื ื‘ืคื•ืจืžื˜: Donald(sh_clerk)
ื”ื—ืœื˜ื”

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

ืฉื™ืžื•ืฉ ื‘ืคื•ื ืงืฆื™ื•ืช ืฉืœ ืฉื•ืจื” ืื—ืช ืœื”ืชืืžื” ืื™ืฉื™ืช ืฉืœ ื”ืคืœื˜

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืฉืžื ืืจื•ืš ืž-10 ืื•ืชื™ื•ืช
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉื”ืื•ืช 'ื‘' ื‘ืฉืžื (ืœื ืชืœื•ื™ ืจื™ืฉื™ื•ืช)
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืฉืžื ืžื›ื™ืœ ืœืคื—ื•ืช 2 ืื•ืชื™ื•ืช 'ื'
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉื”ืฉื›ืจ ืฉืœื”ื ื”ื•ื ื›ืคื•ืœื” ืฉืœ 1000
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืืช ื”ืžืกืคืจ ื”ืจืืฉื•ืŸ ื‘ืŸ 3 ื”ืกืคืจื•ืช ืฉืœ ืžืกืคืจ ื”ื˜ืœืคื•ืŸ ืฉืœ ื”ืขื•ื‘ื“ ืื ื”ืžืกืคืจ ืฉืœื• ื”ื•ื ื‘ืคื•ืจืžื˜ ะฅะฅะฅ.ะฅะฅะฅ.ะฅะฅะฅะฅ
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืžื—ืœืงื•ืช. ืงื‘ืœ ืืช ื”ืžื™ืœื” ื”ืจืืฉื•ื ื” ืžืฉื ื”ืžื—ืœืงื” ืขื‘ื•ืจ ืืœื” ืขื ื™ื•ืชืจ ืžืžื™ืœื” ืื—ืช ื‘ืฉื
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืฉืžื•ืช ืขื•ื‘ื“ื™ื ืœืœื ื”ืื•ืช ื”ืจืืฉื•ื ื” ื•ื”ืื—ืจื•ื ื” ื‘ืฉื
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉื”ืื•ืช ื”ืื—ืจื•ื ื” ืฉืœื”ื ื‘ืฉื ืฉื•ื•ื” ืœ'm' ื•ืื•ืจืš ื”ืฉื ื’ื“ื•ืœ ืž-5
ื”ื—ืœื˜ื”

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

ืฉื•ืœื—ืŸ ื›ืคื•ืœ. ืงื‘ืœื• ืืช ื”ืชืืจื™ืš ืฉืœ ื™ื•ื ืฉื™ืฉื™ ื”ื‘ื
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืขื•ื‘ื“ื™ื ื‘ื—ื‘ืจื” ืœืžืขืœื” ืž-17 ืฉื ื™ื
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉื”ืกืคืจื” ื”ืื—ืจื•ื ื” ืฉืœ ืžืกืคืจ ื”ื˜ืœืคื•ืŸ ืฉืœื”ื ื”ื™ื ืื™ ื–ื•ื’ื™ืช ื•ืžื•ืจื›ื‘ืช ืž-3 ืžืกืคืจื™ื ืžื•ืคืจื“ื™ื ื‘ื ืงื•ื“ื”
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืขืจืš ื”-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';

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืขืœ ื™ื“ื™ ื”ื—ืœืคืช ื›ืœ '.' ื‘ืขืจืš PHONE_NUMBER ืขืœ '-'
ื”ื—ืœื˜ื”

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

ืฉื™ืžื•ืฉ ื‘ืคื•ื ืงืฆื™ื•ืช ื”ืžืจื” ื•ื‘ื™ื˜ื•ื™ื™ื ืžื•ืชื ื™ื

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉื”ื’ื™ืขื• ืœืขื‘ื•ื“ื” ื‘ื™ื•ื ื”ืจืืฉื•ืŸ ืฉืœ ื”ื—ื•ื“ืฉ (ื›ืœ)
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉื”ื’ื™ืขื• ืœืขื‘ื•ื“ื” ื‘-2008
ื”ื—ืœื˜ื”

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

ืฉื•ืœื—ืŸ ื›ืคื•ืœ. ื”ืฆื’ ืืช ื”ืชืืจื™ืš ืฉืœ ืžื—ืจ ื‘ืคื•ืจืžื˜: ืžื—ืจ ื”ื™ื•ื ื”ืฉื ื™ ืฉืœ ื™ื ื•ืืจ
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ื•ืชืืจื™ืš ื”ื”ืชื—ืœื” ืฉืœื”ื ื‘ืคื•ืจืžื˜: 21 ื‘ื™ื•ื ื™, 2007
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืขื•ื‘ื“ื™ื ืขื ืฉื›ืจ ืžื•ื’ื“ืœ ื‘-20%. ื”ืฆื’ ืžืฉื›ื•ืจืช ืขื ืกื™ืžืŸ ื“ื•ืœืจ
ื”ื—ืœื˜ื”

SELECT first_name, TO_CHAR (salary + salary * 0.20, 'fm$999,999.00') new_salary
  FROM 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'; 

ืฉื•ืœื—ืŸ ื›ืคื•ืœ. ื™ื™ืฆื ืชืืจื™ืš ื ื•ื›ื—ื™, + ืฉื ื™ื™ื”, + ื“ืงื”, + ืฉืขื”, + ื™ื•ื, + ื—ื•ื“ืฉ, + ืฉื ื”
ื”ื—ืœื˜ื”

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;

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ืขื ืžืฉื›ื•ืจื•ืช ืžืœืื•ืช (ืžืฉื›ื•ืจืช + ืขืžืœื”_pct(%)) ื‘ืคื•ืจืžื˜: $24,000.00
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ื•ืžื™ื“ืข ืขืœ ื–ืžื™ื ื•ืช ืžืขื ืงื™ ื”ืฉื›ืจ (ื›ืŸ/ืœื)
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืืช ืจืžืช ื”ืฉื›ืจ ืฉืœ ื›ืœ ืขื•ื‘ื“: ืคื—ื•ืช ืž-5000 ื ื—ืฉื‘ ืœืจืžื” ื ืžื•ื›ื”, ื’ื“ื•ืœ ืž-5000 ืื• ืฉื•ื•ื” ืœ-10000 ื•ืคื—ื•ืช ืž-10000 ื ื—ืฉื‘ ืœืจืžื” ื ื•ืจืžืœื™ืช, ื’ื“ื•ืœ ืื• ืฉื•ื•ื” ืœ-XNUMX ื ื—ืฉื‘ ืœืจืžื” ื’ื‘ื•ื”ื”
ื”ื—ืœื˜ื”

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;

ื˜ื‘ืœืช ืžื“ื™ื ื•ืช. ืขื‘ื•ืจ ื›ืœ ืžื“ื™ื ื”, ื”ืฆื’ ืืช ื”ืื–ื•ืจ ืฉื‘ื• ื”ื™ื ืžืžื•ืงืžืช: 1-ืื™ืจื•ืคื”, 2-ืืžืจื™ืงื”, 3-ืืกื™ื”, 4-ืืคืจื™ืงื” (ืœืœื ื”ืฆื˜ืจืคื•ืช)
ื”ื—ืœื˜ื”

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;

ื“ื™ื•ื•ื— ืขืœ ื ืชื•ื ื™ื ืžืฆื˜ื‘ืจื™ื ื‘ืืžืฆืขื•ืช ืคื•ื ืงืฆื™ื•ืช ื”ืงื‘ื•ืฆื”

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ื“ื•ื— ืœืคื™ 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;

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ื›ืžื” ืขื•ื‘ื“ื™ื ืฉืฉืžื ืžืชื—ื™ืœ ื‘ืื•ืชื” ืื•ืช? ืžื™ื™ืŸ ืœืคื™ ื›ืžื•ืช. ื”ืฆื’ ืจืง ืืช ืืœื” ืฉื‘ื”ื ื”ืžืกืคืจ ื’ื“ื•ืœ ืž-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;

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ื›ืžื” ืขื•ื‘ื“ื™ื ืขื•ื‘ื“ื™ื ื‘ืื•ืชื” ืžื—ืœืงื” ื•ืžืงื‘ืœื™ื ืืช ืื•ืชื” ืฉื›ืจ?
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ื“ื•ื— ืฉืœ ื›ืžื” ืขื•ื‘ื“ื™ื ื”ืชืงื‘ืœื• ืœืขื‘ื•ื“ื” ื‘ื›ืœ ื™ื•ื ื‘ืฉื‘ื•ืข. ืžื™ื™ืŸ ืœืคื™ ื›ืžื•ืช
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ื“ื•ื— ืขืœ ื›ืžื” ืขื•ื‘ื“ื™ื ื”ืชืงื‘ืœื• ืœืขื‘ื•ื“ื” ืœืคื™ ืฉื ื”. ืžื™ื™ืŸ ืœืคื™ ื›ืžื•ืช
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืืช ืžืกืคืจ ื”ืžื—ืœืงื•ืช ืฉื™ืฉ ื‘ื”ืŸ ืขื•ื‘ื“ื™ื
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืจืฉื™ืžื” ืฉืœ department_id ืขื ื™ื•ืชืจ ืž-30 ืขื•ื‘ื“ื™ื
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืžื—ืœืงื•ืช_ืžื–ื”ื•ืช ื•ืืช ื”ืฉื›ืจ ื”ืžืžื•ืฆืข ื”ืžืขื•ื’ืœ ืฉืœ ื”ืขื•ื‘ื“ื™ื ื‘ื›ืœ ืžื—ืœืงื”.
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืžื“ื™ื ื•ืช. ืงื‘ืœ ืจืฉื™ืžื” ืฉืœ ืกื›ื•ื region_id ืฉืœ ื›ืœ ื”ืื•ืชื™ื•ืช ืฉืœ ื›ืœ country_names ืฉื‘ื”ืŸ ื™ื•ืชืจ ืž-60
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืžื–ื”ื”_ืžื—ืœืงื” ืฉื‘ื” ืขื•ื‘ื“ื™ื ืขื•ื‘ื“ื™ื ืฉืœ ืžืกืคืจ (>1) ืžื–ื”ื”_ืชืคืงื™ื“
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืจืฉื™ืžื” ืฉืœ ืžื ื”ืœ_ืžื–ื”ื” ืฉืžืกืคืจ ื”ื›ืคื•ืคื™ื ืœื• ื’ื“ื•ืœ ืž-5 ื•ืกื›ื•ื ื›ืœ ื”ืžืฉื›ื•ืจื•ืช ืฉืœ ื”ื›ืคื•ืคื™ื ืœื• ื’ื“ื•ืœ ืž-50000
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืžื ื”ืœ_ืžื–ื”ื” ืฉื”ืฉื›ืจ ื”ืžืžื•ืฆืข ืฉืœ ื›ืœ ื”ื›ืคื•ืคื™ื ืœื• ื”ื•ื ื‘ื™ืŸ 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;

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืืช ื”ืฉื›ืจ ื”ืžืงืกื™ืžืœื™ ืžื›ืœ ื”ืขื•ื‘ื“ื™ื 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';

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืืช ื”ืฉื›ืจ ื”ืžืงืกื™ืžืœื™ ืžื‘ื™ืŸ ื›ืœ ื”ืžืฉื›ื•ืจื•ืช ื”ืžืžื•ืฆืขื•ืช ืœืžื—ืœืงื”
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœ ืืช ืžืกืคืจ ื”ืขื•ื‘ื“ื™ื ืขื ืื•ืชื• ืžืกืคืจ ืื•ืชื™ื•ืช ื‘ืฉืžื. ื‘ืžืงื‘ื™ืœ, ื”ืฆื’ ืจืง ืืช ืžื™ ืฉืฉืžื ืืจื•ืš ืž-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);

ื”ืฆื’ืช ื ืชื•ื ื™ื ืžืžืกืคืจ ื˜ื‘ืœืื•ืช ื‘ืืžืฆืขื•ืช ื—ื™ื‘ื•ืจื™ื

ืขื•ื‘ื“ื™ ื˜ื‘ืœื”, ืžื—ืœืงื•ืช, ืžื™ืงื•ืžื™ื, ืžื“ื™ื ื•ืช, ืื–ื•ืจื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืื–ื•ืจื™ื ื•ืžืกืคืจ ื”ืขื•ื‘ื“ื™ื ื‘ื›ืœ ืื–ื•ืจ
ื”ื—ืœื˜ื”

  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;

ืขื•ื‘ื“ื™ ื˜ื‘ืœื”, ืžื—ืœืงื•ืช, ืžื™ืงื•ืžื™ื, ืžื“ื™ื ื•ืช, ืื–ื•ืจื™ื. ืงื‘ืœ ืžื™ื“ืข ืžืคื•ืจื˜ ืขืœ ื›ืœ ืขื•ื‘ื“:
First_name, Last_name, Department, 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);

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ื”ืฆื’ ืืช ื›ืœ ื”ืžื ื”ืœื™ื ืฉื™ืฉ ืœื”ื ื™ื•ืชืจ ืž-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;

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ื”ืฆื’ ืืช ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืœื ืžื“ื•ื•ื—ื™ื ืœืืฃ ืื—ื“
ื”ื—ืœื˜ื”

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;

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื, ื”ื™ืกื˜ื•ืจื™ื”_ืขื‘ื•ื“ื”. ื˜ื‘ืœืช ื”ืขื•ื‘ื“ื™ื ืžืื—ืกื ืช ืืช ื›ืœ ื”ืขื•ื‘ื“ื™ื. ื˜ื‘ืœืช Job_history ืžืื—ืกื ืช ืขื•ื‘ื“ื™ื ืฉืขื–ื‘ื• ืืช ื”ื—ื‘ืจื”. ืงื‘ืœืช ื“ื•ื— ืขืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื ื•ืžืขืžื“ื ื‘ื—ื‘ืจื” (ืžื•ืขืกืงื™ื ืื• ืขื–ื‘ื• ืืช ื”ื—ื‘ืจื” ืขื ืชืืจื™ืš ื”ืขื–ื™ื‘ื”)
ืœื“ื•ื’ืžื”:
ืฉื_ืฉื | ืกื˜ึธื˜ื•ึผืก
ื’'ื ื™ืคืจ | ืขื–ื‘ ืืช ื”ื—ื‘ืจื” ื‘-31 ื‘ื“ืฆืžื‘ืจ, 2006
ืงืœืจื” | ื›ืจื’ืข ืขื•ื‘ื“
ื”ื—ืœื˜ื”

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

ืขื•ื‘ื“ื™ ื˜ื‘ืœื”, ืžื—ืœืงื•ืช, ืžื™ืงื•ืžื™ื, ืžื“ื™ื ื•ืช, ืื–ื•ืจื™ื. ืงื‘ืœ ืจืฉื™ืžื” ืฉืœ ืขื•ื‘ื“ื™ื ื”ืžืชื’ื•ืจืจื™ื ื‘ืื™ืจื•ืคื” (ืฉื_ืื–ื•ืจ)
ื”ื—ืœื˜ื”

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

ืขื•ื‘ื“ื™ ืฉื•ืœื—ืŸ, ืžื—ืœืงื•ืช. ื”ืฆื’ ืืช ื›ืœ ื”ืžื—ืœืงื•ืช ืขื ื™ื•ืชืจ ืž-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;

ืขื•ื‘ื“ื™ ืฉื•ืœื—ืŸ, ืžื—ืœืงื•ืช. ื”ืฆื’ ืืช ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืื™ื ื ื‘ืืฃ ืžื—ืœืงื”
ื”ื—ืœื˜ื”

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;

ืขื•ื‘ื“ื™ ืฉื•ืœื—ืŸ, ืžื—ืœืงื•ืช. ื”ืฆื’ ืืช ื›ืœ ื”ืžื—ืœืงื•ืช ืœืœื ืขื•ื‘ื“ื™ื
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ื”ืฆื’ ืืช ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืื™ืŸ ืœื”ื ื›ืคื™ืคื™ื
ื”ื—ืœื˜ื”

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

ืขื•ื‘ื“ื™ ืฉื•ืœื—ืŸ, ืžืฉืจื•ืช, ืžื—ืœืงื•ืช. ื”ืฆื’ ืขื•ื‘ื“ื™ื ื‘ืคื•ืจืžื˜: First_name, Job_title, Department_name.
ืœื“ื•ื’ืžื”:
ืฉื_ืฉื | ืชืคืงื™ื“ | ืฉื ืžื—ืœืงื”
ื“ื•ื ืœื“ | ืžืฉืœื•ื— | ืคืงื™ื“ ืžืฉืœื•ื—
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืขื•ื‘ื“ื™ื ืฉืžื ื”ืœื™ื”ื ืงื™ื‘ืœื• ืขื‘ื•ื“ื” ื‘ืฉื ืช 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');

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืขื•ื‘ื“ื™ื ืฉืžื ื”ืœื™ื”ื ืงื™ื‘ืœื• ืขื‘ื•ื“ื” ื‘ื—ื•ื“ืฉ ื™ื ื•ืืจ ืฉืœ ื›ืœ ืฉื ื” ื•ืื•ืจืš ืชืคืงื™ื“_ื›ื•ืชืจืช ื”ืขื•ื‘ื“ื™ื ื”ืœืœื• ื”ื•ื ื™ื•ืชืจ ืž-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;

ืฉื™ืžื•ืฉ ื‘ืฉืื™ืœืชื•ืช ืžืฉื ื” ืœืคืชืจื•ืŸ ืฉืื™ืœืชื•ืช

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืขื•ื‘ื“ื™ื ืขื ื”ืฉื ื”ืืจื•ืš ื‘ื™ื•ืชืจ.
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืขื•ื‘ื“ื™ื ืขื ืฉื›ืจ ื’ื‘ื•ื” ืžื”ืฉื›ืจ ื”ืžืžื•ืฆืข ืฉืœ ื›ืœ ื”ืขื•ื‘ื“ื™ื.
ื”ื—ืœื˜ื”

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

ืขื•ื‘ื“ื™ ืฉื•ืœื—ืŸ, ืžื—ืœืงื•ืช, ืžื™ืงื•ืžื™ื. ืงื‘ืœื• ืืช ื”ืขื™ืจ ืฉื‘ื” ื”ืขื•ื‘ื“ื™ื ืžืจื•ื•ื™ื—ื™ื ื”ื›ื™ ืคื—ื•ืช ื‘ืกืš ื”ื›ืœ.
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืขื•ื‘ื“ื™ื ืฉื”ืžื ื”ืœ ืฉืœื”ื ืžืงื‘ืœ ืฉื›ืจ ืฉืœ ื™ื•ืชืจ ืž-15000.
ื”ื—ืœื˜ื”

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

ืขื•ื‘ื“ื™ ืฉื•ืœื—ืŸ, ืžื—ืœืงื•ืช. ื”ืฆื’ ืืช ื›ืœ ื”ืžื—ืœืงื•ืช ืœืœื ืขื•ื‘ื“ื™ื
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ื”ืฆื’ ืืช ื›ืœ ื”ืขื•ื‘ื“ื™ื ืฉืื™ื ื ืžื ื”ืœื™ื
ื”ื—ืœื˜ื”

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

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ื”ืฆื’ ืืช ื›ืœ ื”ืžื ื”ืœื™ื ืฉื™ืฉ ืœื”ื ื™ื•ืชืจ ืž-6 ืขื•ื‘ื“ื™ื
ื”ื—ืœื˜ื”

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

ืขื•ื‘ื“ื™ ืฉื•ืœื—ืŸ, ืžื—ืœืงื•ืช. ื”ืฆื’ ืขื•ื‘ื“ื™ื ืฉืขื•ื‘ื“ื™ื ื‘ืžื—ืœืงืช ื”-IT
ื”ื—ืœื˜ื”

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

ืขื•ื‘ื“ื™ ืฉื•ืœื—ืŸ, ืžืฉืจื•ืช, ืžื—ืœืงื•ืช. ื”ืฆื’ ืขื•ื‘ื“ื™ื ื‘ืคื•ืจืžื˜: First_name, Job_title, Department_name.
ืœื“ื•ื’ืžื”:
ืฉื_ืฉื | ืชืคืงื™ื“ | ืฉื ืžื—ืœืงื”
ื“ื•ื ืœื“ | ืžืฉืœื•ื— | ืคืงื™ื“ ืžืฉืœื•ื—
ื”ื—ืœื˜ื”

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;

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืขื•ื‘ื“ื™ื ืฉืžื ื”ืœื™ื”ื ืงื™ื‘ืœื• ืขื‘ื•ื“ื” ื‘ืฉื ืช 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');

ื˜ื‘ืœืช ืขื•ื‘ื“ื™ื. ืงื‘ืœื• ืจืฉื™ืžื” ืฉืœ ืขื•ื‘ื“ื™ื ืฉืžื ื”ืœื™ื”ื ืงื™ื‘ืœื• ืขื‘ื•ื“ื” ื‘ื—ื•ื“ืฉ ื™ื ื•ืืจ ืฉืœ ื›ืœ ืฉื ื” ื•ืื•ืจืš ืชืคืงื™ื“_ื›ื•ืชืจืช ื”ืขื•ื‘ื“ื™ื ื”ืœืœื• ื”ื•ื ื™ื•ืชืจ ืž-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;

ื–ื” ื”ื›ืœ ืœืขืช ืขืชื”.

ืื ื™ ืžืงื•ื•ื” ืฉื”ืžืฉื™ืžื•ืช ื”ื™ื• ืžืขื ื™ื™ื ื•ืช ื•ืžืจื’ืฉื•ืช.
ืื•ืกื™ืฃ ืœืจืฉื™ืžื” ื–ื• ื›ื›ืœ ื”ืืคืฉืจ.
ืืฉืžื— ื’ื ืœื›ืœ ื”ืขืจื” ื•ื”ืฆืขื”.

ื .ื‘: ืื ืžื™ืฉื”ื• ื™ืขืœื” ืขืœ ืžืฉื™ืžื” ืžืขื ื™ื™ื ืช ื‘-SELECT, ื›ืชื‘ื• ื‘ืชื’ื•ื‘ื•ืช, ืื ื™ ืื•ืกื™ืฃ ืื•ืชื” ืœืจืฉื™ืžื”.

ืชื•ื“ื”.

ืžืงื•ืจ: www.habr.com

ื”ื•ืกืคืช ืชื’ื•ื‘ื”