ΠΠ΄ΡΠ°Π²Π΅ΠΉ Habr!
ΠΠΎΠ²Π΅ΡΠ΅ ΠΎΡ 3 Π³ΠΎΠ΄ΠΈΠ½ΠΈ ΠΏΡΠ΅ΠΏΠΎΠ΄Π°Π²Π°ΠΌ SQL Π² ΡΠ°Π·Π»ΠΈΡΠ½ΠΈ ΠΎΠ±ΡΡΠΈΡΠ΅Π»Π½ΠΈ ΡΠ΅Π½ΡΡΠΎΠ²Π΅ ΠΈ Π΅Π΄Π½ΠΎ ΠΎΡ ΠΌΠΎΠΈΡΠ΅ Π½Π°Π±Π»ΡΠ΄Π΅Π½ΠΈΡ Π΅, ΡΠ΅ ΡΡΡΠ΄Π΅Π½ΡΠΈΡΠ΅ ΡΡΠ²ΠΎΡΠ²Π°Ρ ΠΈ ΡΠ°Π·Π±ΠΈΡΠ°Ρ SQL ΠΏΠΎ-Π΄ΠΎΠ±ΡΠ΅, Π°ΠΊΠΎ ΠΈΠΌ ΡΠ΅ Π΄Π°Π΄Π΅ Π·Π°Π΄Π°ΡΠ°, Π° Π½Π΅ ΠΏΡΠΎΡΡΠΎ ΡΠ΅ Π³ΠΎΠ²ΠΎΡΠΈ Π·Π° Π²ΡΠ·ΠΌΠΎΠΆΠ½ΠΎΡΡΠΈΡΠ΅ ΠΈ ΡΠ΅ΠΎΡΠ΅ΡΠΈΡΠ½ΠΈΡΠ΅ ΠΎΡΠ½ΠΎΠ²ΠΈ.
Π ΡΠ°Π·ΠΈ ΡΡΠ°ΡΠΈΡ ΡΠ΅ ΡΠΏΠΎΠ΄Π΅Π»Ρ Ρ Π²Π°Ρ ΠΌΠΎΡ ΡΠΏΠΈΡΡΠΊ ΡΡΡ Π·Π°Π΄Π°ΡΠΈ, ΠΊΠΎΠΈΡΠΎ Π΄Π°Π²Π°ΠΌ Π½Π° ΡΡΠ΅Π½ΠΈΡΠΈΡΠ΅ ΠΊΠ°ΡΠΎ Π΄ΠΎΠΌΠ°ΡΠ½Π° ΡΠ°Π±ΠΎΡΠ° ΠΈ Π²ΡΡΡ Ρ ΠΊΠΎΠΈΡΠΎ ΠΏΡΠΎΠ²Π΅ΠΆΠ΄Π°ΠΌΠ΅ ΡΠ°Π·Π»ΠΈΡΠ½ΠΈ Π²ΠΈΠ΄ΠΎΠ²Π΅ ΠΌΠΎΠ·ΡΡΠ½ΠΈ Π°ΡΠ°ΠΊΠΈ, ΠΊΠΎΠ΅ΡΠΎ Π²ΠΎΠ΄ΠΈ Π΄ΠΎ Π΄ΡΠ»Π±ΠΎΠΊΠΎ ΠΈ ΡΡΠ½ΠΎ ΡΠ°Π·Π±ΠΈΡΠ°Π½Π΅ Π½Π° SQL.
SQL (ΛΙsΛkjuΛΙl; Π°Π½Π³Π». ΡΡΡΡΠΊΡΡΡΠΈΡΠ°Π½ Π΅Π·ΠΈΠΊ Π·Π° Π·Π°ΡΠ²ΠΊΠΈ) Π΅ Π΄Π΅ΠΊΠ»Π°ΡΠ°ΡΠΈΠ²Π΅Π½ Π΅Π·ΠΈΠΊ Π·Π° ΠΏΡΠΎΠ³ΡΠ°ΠΌΠΈΡΠ°Π½Π΅, ΠΈΠ·ΠΏΠΎΠ»Π·Π²Π°Π½ Π·Π° ΡΡΠ·Π΄Π°Π²Π°Π½Π΅, ΠΌΠΎΠ΄ΠΈΡΠΈΡΠΈΡΠ°Π½Π΅ ΠΈ ΡΠΏΡΠ°Π²Π»Π΅Π½ΠΈΠ΅ Π½Π° Π΄Π°Π½Π½ΠΈ Π² ΡΠ΅Π»Π°ΡΠΈΠΎΠ½Π½Π° Π±Π°Π·Π° Π΄Π°Π½Π½ΠΈ, ΡΠΏΡΠ°Π²Π»ΡΠ²Π°Π½Π° ΠΎΡ ΠΏΠΎΠ΄Ρ
ΠΎΠ΄ΡΡΠ° ΡΠΈΡΡΠ΅ΠΌΠ° Π·Π° ΡΠΏΡΠ°Π²Π»Π΅Π½ΠΈΠ΅ Π½Π° Π±Π°Π·Π° Π΄Π°Π½Π½ΠΈ.
ΠΠΎΠΆΠ΅ΡΠ΅ Π΄Π° ΠΏΡΠΎΡΠ΅ΡΠ΅ΡΠ΅ Π·Π° 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-ΡΠΈ ΠΎΡΠ΄Π΅Π» (department_id) ΡΡΡ Π·Π°ΠΏΠ»Π°ΡΠ° (salary) Π½Π°Π΄ 4000
Π Π΅ΡΠ΅Π½ΠΈΠ΅
SELECT *
FROM employees
WHERE department_id = 50 AND salary > 4000;
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ Π½Π° Π²ΡΠΈΡΠΊΠΈ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ ΠΎΡ 20-ΡΠΈ ΠΈ ΠΎΡ 30-ΡΠΈ ΠΎΡΠ΄Π΅Π» (department_id)
Π Π΅ΡΠ΅Π½ΠΈΠ΅
SELECT *
FROM employees
WHERE department_id = 20 OR department_id = 30;
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ Π½Π° Π²ΡΠΈΡΠΊΠΈ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ, ΡΠΈΡΡΠΎ ΠΏΠΎΡΠ»Π΅Π΄Π½Π° Π±ΡΠΊΠ²Π° Π² ΠΈΠΌΠ΅ΡΠΎ Π΅ βΠ°β
Π Π΅ΡΠ΅Π½ΠΈΠ΅
SELECT *
FROM employees
WHERE first_name LIKE '%a';
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ Π½Π° Π²ΡΠΈΡΠΊΠΈ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ ΠΎΡ 50-ΡΠΈ ΠΈ ΠΎΡ 80-ΡΠΈ ΠΎΡΠ΄Π΅Π» (department_id), ΠΊΠΎΠΈΡΠΎ ΠΈΠΌΠ°Ρ Π±ΠΎΠ½ΡΡ (ΡΡΠΎΠΉΠ½ΠΎΡΡΡΠ° Π² ΠΊΠΎΠ»ΠΎΠ½Π°ΡΠ° 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;
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ Π½Π° Π²ΡΠΈΡΠΊΠΈ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ, ΠΊΠΎΠΈΡΠΎ ΠΈΠΌΠ°Ρ Π±ΡΠΊΠ²Π°ΡΠ° βbβ Π² ΠΈΠΌΠ΅ΡΠΎ ΡΠΈ (Π±Π΅Π· Π·Π½Π°ΡΠ΅Π½ΠΈΠ΅ Π·Π° ΠΌΠ°Π»ΠΊΠΈ ΠΈ Π³ΠΎΠ»Π΅ΠΌΠΈ Π±ΡΠΊΠ²ΠΈ)
Π Π΅ΡΠ΅Π½ΠΈΠ΅
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 ΡΠ΅ ΡΡΠΈΡΠ° Π·Π° Π²ΠΈΡΠΎΠΊΠΎ Π½ΠΈΠ²ΠΎ
Π Π΅ΡΠ΅Π½ΠΈΠ΅
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-ΠΡΡΠΈΠΊΠ° (Π±Π΅Π· 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;
ΠΡΡΠΈΡΠ°Π½Π΅ Π½Π° ΠΎΠ±ΠΎΠ±ΡΠ΅Π½ΠΈ Π΄Π°Π½Π½ΠΈ Ρ ΠΏΠΎΠΌΠΎΡΡΠ° Π½Π° Π³ΡΡΠΏΠΎΠ²ΠΈΡΠ΅ ΡΡΠ½ΠΊΡΠΈΠΈ
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΠΎΡΡΠ΅Ρ ΠΏΠΎ 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;
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ Ρ department_ids ΠΈ Π·Π°ΠΊΡΡΠ³Π»Π΅Π½Π°ΡΠ° ΡΡΠ΅Π΄Π½Π° Π·Π°ΠΏΠ»Π°ΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅ Π²ΡΠ² Π²ΡΠ΅ΠΊΠΈ ΠΎΡΠ΄Π΅Π».
Π Π΅ΡΠ΅Π½ΠΈΠ΅
SELECT department_id, ROUND (AVG (salary)) avg_salary
FROM employees
GROUP BY department_id;
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° Π΄ΡΡΠΆΠ°Π²ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ Ρ region_id ΡΠ±ΠΎΡ ΠΎΡ Π²ΡΠΈΡΠΊΠΈ Π±ΡΠΊΠ²ΠΈ Π½Π° Π²ΡΠΈΡΠΊΠΈ ΠΈΠΌΠ΅Π½Π° Π½Π° Π΄ΡΡΠΆΠ°Π²ΠΈ, Π² ΠΊΠΎΠΈΡΠΎ ΠΏΠΎΠ²Π΅ΡΠ΅ ΠΎΡ 60
Π Π΅ΡΠ΅Π½ΠΈΠ΅
SELECT region_id
FROM countries
GROUP BY region_id
HAVING SUM (LENGTH (country_name)) > 60;
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ Ρ department_id, Π² ΠΊΠΎΠΉΡΠΎ ΡΠ°Π±ΠΎΡΡΡ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ Π½Π° Π½ΡΠΊΠΎΠ»ΠΊΠΎ (>1) job_id
Π Π΅ΡΠ΅Π½ΠΈΠ΅
SELECT department_id
FROM employees
GROUP BY department_id
HAVING COUNT (DISTINCT job_id) > 1;
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ Ρ manager_id, ΡΠΈΠΉΡΠΎ Π±ΡΠΎΠΉ ΠΏΠΎΠ΄ΡΠΈΠ½Π΅Π½ΠΈ Π΅ ΠΏΠΎ-Π³ΠΎΠ»ΡΠΌ ΠΎΡ 5 ΠΈ ΡΡΠΌΠ°ΡΠ° ΠΎΡ Π²ΡΠΈΡΠΊΠΈ Π·Π°ΠΏΠ»Π°ΡΠΈ Π½Π° Π½Π΅Π³ΠΎΠ²ΠΈΡΠ΅ ΠΏΠΎΠ΄ΡΠΈΠ½Π΅Π½ΠΈ Π΅ ΠΏΠΎ-Π³ΠΎΠ»ΡΠΌΠ° ΠΎΡ 50000 XNUMX
Π Π΅ΡΠ΅Π½ΠΈΠ΅
SELECT manager_id
FROM employees
GROUP BY manager_id
HAVING COUNT (*) > 5 AND SUM (salary) > 50000;
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ Ρ 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;
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΠΌΠ°ΠΊΡΠΈΠΌΠ°Π»Π½Π°ΡΠ° Π·Π°ΠΏΠ»Π°ΡΠ° ΠΎΡ Π²ΡΠΈΡΠΊΠΈ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ 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. Π’Π°Π±Π»ΠΈΡΠ°ΡΠ° Employee ΡΡΡ
ΡΠ°Π½ΡΠ²Π° Π²ΡΠΈΡΠΊΠΈ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ. Π’Π°Π±Π»ΠΈΡΠ°ΡΠ° 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);
Π’Π°Π±Π»ΠΈΡΠ° Π‘Π»ΡΠΆΠΈΡΠ΅Π»ΠΈ, ΠΎΡΠ΄Π΅Π»ΠΈ, ΠΌΠ΅ΡΡΠΎΠΏΠΎΠ»ΠΎΠΆΠ΅Π½ΠΈΡ, Π΄ΡΡΠΆΠ°Π²ΠΈ, ΡΠ΅Π³ΠΈΠΎΠ½ΠΈ. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ ΡΡΡ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ, ΠΊΠΎΠΈΡΠΎ ΠΆΠΈΠ²Π΅ΡΡ Π² ΠΠ²ΡΠΎΠΏΠ° (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';
Π’Π°Π±Π»ΠΈΡΠ° Π‘Π»ΡΠΆΠΈΡΠ΅Π»ΠΈ, ΠΎΡΠ΄Π΅Π»ΠΈ. ΠΠΎΠΊΠ°ΠΆΠΈ Π²ΡΠΈΡΠΊΠΈ ΠΎΡΠ΄Π΅Π»ΠΈ Ρ ΠΏΠΎΠ²Π΅ΡΠ΅ ΠΎΡ 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');
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ ΡΡΡ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ, ΡΠΈΠΈΡΠΎ ΠΌΠ΅Π½ΠΈΠ΄ΠΆΡΡΠΈ ΡΠ° ΠΏΠΎΠ»ΡΡΠΈΠ»ΠΈ ΡΠ°Π±ΠΎΡΠ° ΠΏΡΠ΅Π· ΠΌΠ΅ΡΠ΅Ρ ΡΠ½ΡΠ°ΡΠΈ Π½Π° ΠΊΠΎΡΡΠΎ ΠΈ Π΄Π° Π΅ Π³ΠΎΠ΄ΠΈΠ½Π° ΠΈ Π΄ΡΠ»ΠΆΠΈΠ½Π°ΡΠ° Π½Π° 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;
ΠΠ·ΠΏΠΎΠ»Π·Π²Π°Π½Π΅ Π½Π° ΠΏΠΎΠ΄Π·Π°ΡΠ²ΠΊΠΈ Π·Π° ΡΠ΅ΡΠ°Π²Π°Π½Π΅ Π½Π° Π·Π°ΡΠ²ΠΊΠΈ
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ ΡΡΡ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ Ρ Π½Π°ΠΉ-Π΄ΡΠ»Π³ΠΎ ΠΈΠΌΠ΅.
Π Π΅ΡΠ΅Π½ΠΈΠ΅
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 XNUMX.
Π Π΅ΡΠ΅Π½ΠΈΠ΅
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;
Π’Π°Π±Π»ΠΈΡΠ° Π‘Π»ΡΠΆΠΈΡΠ΅Π»ΠΈ, ΠΎΡΠ΄Π΅Π»ΠΈ. ΠΠΎΠΊΠ°ΠΆΠ΅ΡΠ΅ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ, ΠΊΠΎΠΈΡΠΎ ΡΠ°Π±ΠΎΡΡΡ Π² ΠΠ’ ΠΎΡΠ΄Π΅Π»Π°
Π Π΅ΡΠ΅Π½ΠΈΠ΅
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');
Π’Π°Π±Π»ΠΈΡΠ° Π½Π° ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈΡΠ΅. ΠΠ·Π΅ΠΌΠ΅ΡΠ΅ ΡΠΏΠΈΡΡΠΊ ΡΡΡ ΡΠ»ΡΠΆΠΈΡΠ΅Π»ΠΈ, ΡΠΈΠΈΡΠΎ ΠΌΠ΅Π½ΠΈΠ΄ΠΆΡΡΠΈ ΡΠ° ΠΏΠΎΠ»ΡΡΠΈΠ»ΠΈ ΡΠ°Π±ΠΎΡΠ° ΠΏΡΠ΅Π· ΠΌΠ΅ΡΠ΅Ρ ΡΠ½ΡΠ°ΡΠΈ Π½Π° ΠΊΠΎΡΡΠΎ ΠΈ Π΄Π° Π΅ Π³ΠΎΠ΄ΠΈΠ½Π° ΠΈ Π΄ΡΠ»ΠΆΠΈΠ½Π°ΡΠ° Π½Π° 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, ΠΏΠΈΡΠ΅ΡΠ΅ Π² ΠΊΠΎΠΌΠ΅Π½ΡΠ°ΡΠΈΡΠ΅, ΡΠ΅ Ρ Π΄ΠΎΠ±Π°Π²Ρ ΠΊΡΠΌ ΡΠΏΠΈΡΡΠΊΠ°.
ΠΠ»Π°Π³ΠΎΠ΄Π°ΡΡ.
ΠΠ·ΡΠΎΡΠ½ΠΈΠΊ: www.habr.com