ΠΠ΄ΡΠ°Π²ΠΎ, Π₯Π°Π±Ρ!
ΠΠ΅Ρ Π²ΠΈΡΠ΅ ΠΎΠ΄ 3 Π³ΠΎΠ΄ΠΈΠ½Π΅ ΠΏΡΠ΅Π΄Π°ΡΠ΅ΠΌ Π‘ΠΠ Ρ ΡΠ°Π·Π½ΠΈΠΌ ΡΠ΅Π½ΡΡΠΈΠΌΠ° Π·Π° ΠΎΠ±ΡΠΊΡ ΠΈ ΡΠ΅Π΄Π½ΠΎ ΠΎΠ΄ ΠΌΠΎΡΠΈΡ Π·Π°ΠΏΠ°ΠΆΠ°ΡΠ° ΡΠ΅ Π΄Π° ΡΡΡΠ΄Π΅Π½ΡΠΈ Π±ΠΎΡΠ΅ ΡΠ°Π²Π»Π°Π΄Π°Π²Π°ΡΡ ΠΈ ΡΠ°Π·ΡΠΌΠ΅ΡΡ Π‘ΠΠ Π°ΠΊΠΎ ΠΈΠΌ ΡΠ΅ Π΄Π° Π·Π°Π΄Π°ΡΠ°ΠΊ, Π° Π½Π΅ ΡΠ°ΠΌΠΎ Π³ΠΎΠ²ΠΎΡΠ΅ ΠΎ ΠΌΠΎΠ³ΡΡΠ½ΠΎΡΡΠΈΠΌΠ° ΠΈ ΡΠ΅ΠΎΡΠ΅ΡΡΠΊΠΈΠΌ ΠΎΡΠ½ΠΎΠ²Π°ΠΌΠ°.
Π£ ΠΎΠ²ΠΎΠΌ ΡΠ»Π°Π½ΠΊΡ ΠΏΠΎΠ΄Π΅Π»ΠΈΡΡ ΡΠ° Π²Π°ΠΌΠ° ΡΠ²ΠΎΡΡ Π»ΠΈΡΡΡ ΠΏΡΠΎΠ±Π»Π΅ΠΌΠ° ΠΊΠΎΡΠ΅ Π΄Π°ΡΠ΅ΠΌ ΡΡΠ΅Π½ΠΈΡΠΈΠΌΠ° ΠΊΠ°ΠΎ Π΄ΠΎΠΌΠ°ΡΠΈ Π·Π°Π΄Π°ΡΠ°ΠΊ ΠΈ Π½Π° ΠΊΠΎΡΠΈΠΌΠ° ΡΠΏΡΠΎΠ²ΠΎΠ΄ΠΈΠΌΠΎ ΡΠ°Π·Π½Π΅ Π²ΡΡΡΠ΅ Π±ΡΠ°ΠΈΠ½ΡΡΠΎΡΠΌΠΈΠ½Π³Π°, ΡΡΠΎ Π΄ΠΎΠ²ΠΎΠ΄ΠΈ Π΄ΠΎ Π΄ΡΠ±ΠΎΠΊΠΎΠ³ ΠΈ ΡΠ°ΡΠ½ΠΎΠ³ ΡΠ°Π·ΡΠΌΠ΅Π²Π°ΡΠ° Π‘ΠΠ-Π°.
Π‘ΠΠ (ΛΙΡΛΠΊΡΡΛΙΠ»; Π΅Π½Π³Π»Π΅ΡΠΊΠΈ ΡΡΡΡΠΊΡΡΡΠΈΡΠ°Π½ΠΈ ΡΠ΅Π·ΠΈΠΊ ΡΠΏΠΈΡΠ°) ΡΠ΅ Π΄Π΅ΠΊΠ»Π°ΡΠ°ΡΠΈΠ²Π½ΠΈ ΠΏΡΠΎΠ³ΡΠ°ΠΌΡΠΊΠΈ ΡΠ΅Π·ΠΈΠΊ ΠΊΠΎΡΠΈ ΡΠ΅ ΠΊΠΎΡΠΈΡΡΠΈ Π·Π° ΠΊΡΠ΅ΠΈΡΠ°ΡΠ΅, ΠΌΠΎΠ΄ΠΈΡΠΈΠΊΠΎΠ²Π°ΡΠ΅ ΠΈ ΡΠΏΡΠ°Π²ΡΠ°ΡΠ΅ ΠΏΠΎΠ΄Π°ΡΠΈΠΌΠ° Ρ ΡΠ΅Π»Π°ΡΠΈΠΎΠ½ΠΎΡ Π±Π°Π·ΠΈ ΠΏΠΎΠ΄Π°ΡΠ°ΠΊΠ° ΠΊΠΎΡΠΎΠΌ ΡΠΏΡΠ°Π²ΡΠ° ΠΎΠ΄Π³ΠΎΠ²Π°ΡΠ°ΡΡΡΠΈ ΡΠΈΡΡΠ΅ΠΌ Π·Π° ΡΠΏΡΠ°Π²ΡΠ°ΡΠ΅ Π±Π°Π·ΠΎΠΌ ΠΏΠΎΠ΄Π°ΡΠ°ΠΊΠ°.
Π Π‘ΠΠ-Ρ ΠΌΠΎΠΆΠ΅ΡΠ΅ ΡΠΈΡΠ°ΡΠΈ ΠΈΠ· ΡΠ°Π·Π½ΠΈΡ
ΠΠ²Π°Ρ ΡΠ»Π°Π½Π°ΠΊ Π½ΠΈΡΠ΅ Π½Π°ΠΌΠ΅ΡΠ΅Π½ Π΄Π° Π²Π°Ρ Π½Π°ΡΡΠΈ Π‘ΠΠ ΠΎΠ΄ Π½ΡΠ»Π΅.
ΠΠ° ΠΈΠ΄Π΅ΠΌΠΎ.
ΠΠΎΡΠΈΡΡΠΈΡΠ΅ΠΌΠΎ Π΄ΠΎΠ±ΡΠΎ ΠΏΠΎΠ·Π½Π°ΡΠΎ
ΠΠ°ΠΏΠΎΠΌΠΈΡΠ΅ΠΌ Π΄Π° ΡΠ΅ΠΌΠΎ ΡΠ°Π·ΠΌΠ°ΡΡΠ°ΡΠΈ ΡΠ°ΠΌΠΎ Π‘ΠΠΠΠ¦Π’ Π·Π°Π΄Π°ΡΠΊΠ΅. ΠΠ²Π΄Π΅ Π½Π΅ΠΌΠ° ΠΠΠ ΠΈΠ»ΠΈ ΠΠΠ Π·Π°Π΄Π°ΡΠ°ΠΊΠ°.
Π·Π°Π΄Π°ΡΠΈ
ΠΠ³ΡΠ°Π½ΠΈΡΠ°Π²Π°ΡΠ΅ ΠΈ ΡΠΎΡΡΠΈΡΠ°ΡΠ΅ ΠΏΠΎΠ΄Π°ΡΠ°ΠΊΠ°
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ° ΠΈΠ½ΡΠΎΡΠΌΠ°ΡΠΈΡΠ°ΠΌΠ° ΠΎ ΡΠ²ΠΈΠΌ Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΠΌΠ°
ΠΎΠ΄Π»ΡΠΊΠ°
SELECT * FROM employees
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ²ΠΈΡ
Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΠΏΠΎ ΠΈΠΌΠ΅Π½Ρ 'ΠΠ°Π²ΠΈΠ΄'
ΠΎΠ΄Π»ΡΠΊΠ°
SELECT *
FROM employees
WHERE first_name = 'David';
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ²ΠΈΡ
Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΡΠ° ΡΠΎΠ±_ΠΈΠ΄ ΡΠ΅Π΄Π½Π°ΠΊΠΈΠΌ 'ΠΠ’_ΠΠ ΠΠ'
ΠΎΠ΄Π»ΡΠΊΠ°
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;
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ²ΠΈΡ
Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΡΠΈΡΠ΅ ΡΠ΅ ΠΏΠΎΡΠ»Π΅Π΄ΡΠ΅ ΡΠ»ΠΎΠ²ΠΎ Ρ ΠΈΠΌΠ΅Π½Ρ 'Π°'
ΠΎΠ΄Π»ΡΠΊΠ°
SELECT *
FROM employees
WHERE first_name LIKE '%a';
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ²ΠΈΡ
Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΠΈΠ· 50. ΠΈ 80. ΠΎΠ΄Π΅ΡΠ΅ΡΠ° (Π΄Π΅ΠΏΠ°ΡΡΠΌΠ΅Π½Ρ_ΠΈΠ΄) ΠΊΠΎΡΠΈ ΠΈΠΌΠ°ΡΡ Π±ΠΎΠ½ΡΡ (Π²ΡΠ΅Π΄Π½ΠΎΡΡ Ρ ΠΊΠΎΠ»ΠΎΠ½ΠΈ Π¦ΠΎΠΌΠΌΠΈΡΡΠΈΠΎΠ½_ΠΏΡΡ Π½ΠΈΡΠ΅ ΠΏΡΠ°Π·Π½Π°)
ΠΎΠ΄Π»ΡΠΊΠ°
SELECT *
FROM employees
WHERE (department_id = 50 OR department_id = 80)
AND commission_pct IS NOT NULL;
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ²ΠΈΡ
Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΡΠΈΡΠ° ΠΈΠΌΠ΅Π½Π° ΡΠ°Π΄ΡΠΆΠ΅ Π½Π°ΡΠΌΠ°ΡΠ΅ 2 ΡΠ»ΠΎΠ²Π° 'Π½'
ΠΎΠ΄Π»ΡΠΊΠ°
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;
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΡΠ° ΡΠΈΡ
ΠΎΠ²ΠΈΠΌ ΠΏΠΎΠ·ΠΈΡΠΈΡΠ°ΠΌΠ° Ρ ΡΠΎΡΠΌΠ°ΡΡ: ΠΠΎΠ½Π°Π»Π΄(ΡΡ
_ΡΠ»Π΅ΡΠΊ)
ΠΎΠ΄Π»ΡΠΊΠ°
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;
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ ΠΏΡΠ²ΠΈ ΡΡΠΎΡΠΈΡΡΠ΅Π½ΠΈ Π±ΡΠΎΡ ΡΠ΅Π»Π΅ΡΠΎΠ½Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΎΠ³ Π°ΠΊΠΎ ΡΠ΅ ΡΠ΅Π³ΠΎΠ² Π±ΡΠΎΡ Ρ ΡΠΎΡΠΌΠ°ΡΡ ΠΠ‘ΠΠ‘ΠΠ‘.ΠΠ‘ΠΠ‘ΠΠ‘.ΠΠ‘ΠΠ‘ΠΠ‘ΠΠ‘
ΠΎΠ΄Π»ΡΠΊΠ°
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;
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ²ΠΈΡ
Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΡΠΈΡΠ΅ ΡΠ΅ ΠΏΠΎΡΠ»Π΅Π΄ΡΠ΅ ΡΠ»ΠΎΠ²ΠΎ Ρ ΠΈΠΌΠ΅Π½Ρ βΠΌβ ΠΈ ΡΠΈΡΠ΅ ΡΠ΅ ΠΈΠΌΠ΅ Π΄ΡΠΆΠ΅ ΠΎΠ΄ 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;
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ²ΠΈΡ
Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΡΠΈΡΠ° Π²ΡΠ΅Π΄Π½ΠΎΡΡ ΡΠΎΠ±_ΠΈΠ΄ ΠΏΠΎΡΠ»Π΅ Π·Π½Π°ΠΊΠ° '_' ΠΈΠΌΠ° Π½Π°ΡΠΌΠ°ΡΠ΅ 3 Π·Π½Π°ΠΊΠ°, Π°Π»ΠΈ ΠΎΠ²Π° Π²ΡΠ΅Π΄Π½ΠΎΡΡ ΠΏΠΎΡΠ»Π΅ '_' Π½ΠΈΡΠ΅ ΡΠ΅Π΄Π½Π°ΠΊΠ° 'Π¦ΠΠΠ Π'
ΠΎΠ΄Π»ΡΠΊΠ°
SELECT *
FROM employees
WHERE LENGTH (SUBSTR (job_id, INSTR (job_id, '_') + 1)) > 3
AND SUBSTR (job_id, INSTR (job_id, '_') + 1) != 'CLERK';
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ²ΠΈΡ
Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΡΠ°ΠΊΠΎ ΡΡΠΎ ΡΠ΅ΡΠ΅ Π·Π°ΠΌΠ΅Π½ΠΈΡΠΈ ΡΠ²Π΅ β.β Ρ Π²ΡΠ΅Π΄Π½ΠΎΡΡΠΈ ΠΠ₯ΠΠΠ_ΠΠ£ΠΠΠΠ Π½Π° '-'
ΠΎΠ΄Π»ΡΠΊΠ°
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.
ΠΎΠ΄Π»ΡΠΊΠ°
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;
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ²ΠΈΡ
Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΡΠ° ΠΏΡΠ½ΠΈΠΌ ΠΏΠ»Π°ΡΠ°ΠΌΠ° (ΠΏΠ»Π°ΡΠ° + ΠΏΡΠΎΠ²ΠΈΠ·ΠΈΡΠ°_ΠΏΡΡ(%)) Ρ ΡΠΎΡΠΌΠ°ΡΡ: $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-ΠΡΡΠΈΠΊΠ° (Π±Π΅Π· ΠΏΡΠΈΠ΄ΡΡΠΆΠΈΠ²Π°ΡΠ°)
ΠΎΠ΄Π»ΡΠΊΠ°
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;
ΠΠ·Π²Π΅ΡΡΠ°Π²Π°ΡΠ΅ ΠΎ Π°Π³ΡΠ΅Π³ΠΈΡΠ°Π½ΠΈΠΌ ΠΏΠΎΠ΄Π°ΡΠΈΠΌΠ° ΠΏΠΎΠΌΠΎΡΡ ΡΡΠ½ΠΊΡΠΈΡΠ° Π³ΡΡΠΏΠ΅
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΡΠΈΠΌΠΈΡΠ΅ ΠΈΠ·Π²Π΅ΡΡΠ°Ρ ΠΎΠ΄ Π΄Π΅ΠΏΠ°ΡΡΠΌΠ΅Π½Ρ_ΠΈΠ΄ ΡΠ° ΠΌΠΈΠ½ΠΈΠΌΠ°Π»Π½ΠΎΠΌ ΠΈ ΠΌΠ°ΠΊΡΠΈΠΌΠ°Π»Π½ΠΎΠΌ Π·Π°ΡΠ°Π΄ΠΎΠΌ, ΡΠ°Π½ΠΈΠΌ ΠΈ ΠΊΠ°ΡΠ½ΠΈΠΌ ΡΠ΅ΡΠΌΠΈΠ½ΠΈΠΌΠ° Π΄ΠΎΠ»Π°ΡΠΊΠ° Π½Π° ΠΏΠΎΡΠ°ΠΎ ΠΈ Π±ΡΠΎΡΠ΅ΠΌ Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. Π‘ΠΎΡΡΠΈΡΠ°Ρ ΠΏΠΎ Π±ΡΠΎΡΡ Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
(ΠΎΠΏΠ°Π΄Π°ΡΡΡΠ΅)
ΠΎΠ΄Π»ΡΠΊΠ°
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;
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ Π΄Π΅ΠΏΠ°ΡΡΠΌΠ΅Π½Ρ_ΠΈΠ΄Ρ ΠΊΠΎΡΠΈ ΠΈΠΌΠ°ΡΡ Π²ΠΈΡΠ΅ ΠΎΠ΄ 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;
Π’Π°Π±Π»Π΅ Π¦ΠΎΡΠ½ΡΡΠΈΠ΅Ρ. ΠΠΎΠ±ΠΈΡΡΠ΅ Π»ΠΈΡΡΡ ΡΠ΅Π³ΠΈΠΎΠ½_ΠΈΠ΄ ΠΊΠ°ΠΎ Π·Π±ΠΈΡ ΡΠ²ΠΈΡ
ΡΠ»ΠΎΠ²Π° ΡΠ²ΠΈΡ
ΠΈΠΌΠ΅Π½Π° Π·Π΅ΠΌΠ°ΡΠ° Ρ ΠΊΠΎΡΠΈΠΌΠ° ΠΈΠΌΠ° Π²ΠΈΡΠ΅ ΠΎΠ΄ 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 ΠΈ ΠΊΠΎΡΠΈ Π½Π΅ ΠΏΡΠΈΠΌΠ°ΡΡ Π±ΠΎΠ½ΡΡΠ΅ (ΡΠΎΠΌΠΌΠΈΡΡΠΈΠΎΠ½_ΠΏΡΡ ΡΠ΅ ΠΏΡΠ°Π·Π°Π½)
ΠΎΠ΄Π»ΡΠΊΠ°
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;
Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
. ΠΠΎΠ±ΠΈΡΡΠ΅ ΠΌΠ°ΠΊΡΠΈΠΌΠ°Π»Π½Ρ ΠΏΠ»Π°ΡΡ ΠΎΠ΄ ΡΠ²ΠΈΡ
Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΡΠΎΠ±_ΠΈΠ΄ ΠΊΠΎΡΠΈ ΡΠ΅ Π·Π°Π²ΡΡΠ°Π²Π° ΡΠ΅ΡΡΡ 'Π‘ΠΠΠΠΠΠ'
ΠΎΠ΄Π»ΡΠΊΠ°
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;
ΠΠ°ΠΏΠΎΡΠ»Π΅Π½ΠΈ Ρ ΡΠ°Π±Π΅Π»ΠΈ, ΠΎΠ΄Π΅ΡΠ΅ΡΠ°, Π»ΠΎΠΊΠ°ΡΠΈΡΠ΅, Π·Π΅ΠΌΡΠ΅, ΡΠ΅Π³ΠΈΠΎΠ½ΠΈ. ΠΠΎΠ±ΠΈΡΡΠ΅ Π΄Π΅ΡΠ°ΡΠ½Π΅ ΠΈΠ½ΡΠΎΡΠΌΠ°ΡΠΈΡΠ΅ ΠΎ ΡΠ²Π°ΠΊΠΎΠΌ Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΎΠΌ:
ΠΠΌΠ΅, ΠΡΠ΅Π·ΠΈΠΌΠ΅, ΠΠ΄Π΅ΡΠ΅ΡΠ΅, ΠΠΎΡΠ°ΠΎ, Π£Π»ΠΈΡΠ°, ΠΡΠΆΠ°Π²Π°, Π Π΅Π³ΠΈΠΎΠ½
ΠΎΠ΄Π»ΡΠΊΠ°
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;
ΠΠ°ΠΏΠΎΡΠ»Π΅Π½ΠΈ Ρ ΡΡΠΎΠ»Ρ, ΠΡΡΠΎΡΠΈΡΠ° ΠΏΠΎΡΠ»Π°. Π’Π°Π±Π΅Π»Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΡ
ΡΡΠ²Π° ΡΠ²Π΅ Π·Π°ΠΏΠΎΡΠ»Π΅Π½Π΅. Π’Π°Π±Π΅Π»Π° ΠΠΎΠ±_Ρ
ΠΈΡΡΠΎΡΠΈ ΡΡΠ²Π° Π·Π°ΠΏΠΎΡΠ»Π΅Π½Π΅ ΠΊΠΎΡΠΈ ΡΡ Π½Π°ΠΏΡΡΡΠΈΠ»ΠΈ ΠΊΠΎΠΌΠΏΠ°Π½ΠΈΡΡ. ΠΠΎΠ±ΠΈΡΡΠ΅ ΠΈΠ·Π²Π΅ΡΡΠ°Ρ ΠΎ ΡΠ²ΠΈΠΌ Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈΠΌΠ° ΠΈ ΡΠΈΡ
ΠΎΠ²ΠΎΠΌ ΡΡΠ°ΡΡΡΡ Ρ ΠΊΠΎΠΌΠΏΠ°Π½ΠΈΡΠΈ (ΡΠ°Π΄ ΠΈΠ»ΠΈ Π½Π°ΠΏΡΡΡΠ°ΡΠ΅ ΠΊΠΎΠΌΠΏΠ°Π½ΠΈΡΠ΅ ΡΠ° Π΄Π°ΡΡΠΌΠΎΠΌ ΠΎΠ΄Π»Π°ΡΠΊΠ°)
ΠΡΠΈΠΌΠ΅Ρ:
ΠΈΠΌΠ΅ | ΡΡΠ°ΡΡΡ
ΠΠ΅Π½Π½ΠΈΡΠ΅Ρ | ΠΠ°ΠΏΡΡΡΠΈΠΎ ΡΠ΅ ΠΊΠΎΠΌΠΏΠ°Π½ΠΈΡΡ 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;
Π‘ΡΠΎΠ»Π½ΠΈ Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈ, ΠΏΠΎΡΠ»ΠΎΠ²ΠΈ, ΠΎΠ΄Π΅ΡΠ΅ΡΠ°. ΠΡΠΈΠΊΠ°ΠΆΠΈΡΠ΅ Π·Π°ΠΏΠΎΡΠ»Π΅Π½Π΅ Ρ ΡΠΎΡΠΌΠ°ΡΡ: ΠΠΌΠ΅_ΠΈΠΌΠ΅, ΠΠ°Π·ΠΈΠ²_ΠΏΠΎΡΠ»Π°, ΠΠΌΠ΅_ΠΎΠ΄ΡΠ΅ΠΊΠ°.
ΠΡΠΈΠΌΠ΅Ρ:
ΠΠΌΠ΅ | ΠΠΎΠ±_ΡΠΈΡΠ»Π΅ | ΠΠ΄Π΅ΡΠ΅ΡΠ΅ ΠΠΌΠ΅
ΠΠΎΠ½Π°Π»Π΄ | ΠΠΎΡΡΠ°Π²Π° | Π¦Π»Π΅ΡΠΊ Π‘Ρ
ΠΈΠΏΠΏΠΈΠ½Π³
ΠΎΠ΄Π»ΡΠΊΠ°
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;
Π‘ΡΠΎΠ»Π½ΠΈ ΡΠ»ΡΠΆΠ±Π΅Π½ΠΈΡΠΈ, ΠΎΠ΄Π΅ΡΠ΅ΡΠ°. ΠΠΎΠΊΠ°ΠΆΠΈΡΠ΅ Π·Π°ΠΏΠΎΡΠ»Π΅Π½Π΅ ΠΊΠΎΡΠΈ ΡΠ°Π΄Π΅ Ρ ΠΠ’ ΠΎΠ΄Π΅ΡΠ΅ΡΡ
ΠΎΠ΄Π»ΡΠΊΠ°
SELECT *
FROM employees
WHERE department_id = (SELECT department_id
FROM departments
WHERE department_name = 'IT');
Π‘ΡΠΎΠ»Π½ΠΈ Π·Π°ΠΏΠΎΡΠ»Π΅Π½ΠΈ, ΠΏΠΎΡΠ»ΠΎΠ²ΠΈ, ΠΎΠ΄Π΅ΡΠ΅ΡΠ°. ΠΡΠΈΠΊΠ°ΠΆΠΈΡΠ΅ Π·Π°ΠΏΠΎΡΠ»Π΅Π½Π΅ Ρ ΡΠΎΡΠΌΠ°ΡΡ: ΠΠΌΠ΅_ΠΈΠΌΠ΅, ΠΠ°Π·ΠΈΠ²_ΠΏΠΎΡΠ»Π°, ΠΠΌΠ΅_ΠΎΠ΄ΡΠ΅ΠΊΠ°.
ΠΡΠΈΠΌΠ΅Ρ:
ΠΠΌΠ΅ | ΠΠΎΠ±_ΡΠΈΡΠ»Π΅ | ΠΠ΄Π΅ΡΠ΅ΡΠ΅ ΠΠΌΠ΅
ΠΠΎΠ½Π°Π»Π΄ | ΠΠΎΡΡΠ°Π²Π° | Π¦Π»Π΅ΡΠΊ Π‘Ρ
ΠΈΠΏΠΏΠΈΠ½Π³
ΠΎΠ΄Π»ΡΠΊΠ°
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;
Π’ΠΎ ΡΠ΅ ΡΠ²Π΅ Π·Π° ΡΠ°Π΄Π°.
ΠΠ°Π΄Π°ΠΌ ΡΠ΅ Π΄Π° ΡΡ Π·Π°Π΄Π°ΡΠΈ Π±ΠΈΠ»ΠΈ Π·Π°Π½ΠΈΠΌΡΠΈΠ²ΠΈ ΠΈ ΡΠ·Π±ΡΠ΄ΡΠΈΠ²ΠΈ.
ΠΠΎΠ΄Π°ΡΡ Π½Π° ΠΎΠ²Ρ Π»ΠΈΡΡΡ Π·Π°Π΄Π°ΡΠ°ΠΊΠ° ΡΡΠΎ ΡΠ΅ Π²ΠΈΡΠ΅ ΠΌΠΎΠ³ΡΡΠ΅.
Π’Π°ΠΊΠΎΡΠ΅ ΡΠ΅ ΠΌΠΈ Π±ΠΈΡΠΈ Π΄ΡΠ°Π³ΠΎ Π΄Π° ΠΏΡΠΈΠΌΠΈΠΌ Π±ΠΈΠ»ΠΎ ΠΊΠ°ΠΊΠ²Π΅ ΠΊΠΎΠΌΠ΅Π½ΡΠ°ΡΠ΅ ΠΈ ΡΡΠ³Π΅ΡΡΠΈΡΠ΅.
ΠΠ‘: ΠΠΊΠΎ Π½Π΅ΠΊΠΎ ΡΠΌΠΈΡΠ»ΠΈ Π·Π°Π½ΠΈΠΌΡΠΈΠ² Π·Π°Π΄Π°ΡΠ°ΠΊ Π‘ΠΠΠΠ¦Π’, ΠΏΠΈΡΠΈΡΠ΅ Ρ ΠΊΠΎΠΌΠ΅Π½ΡΠ°ΡΠΈΠΌΠ° ΠΈ ΡΠ° ΡΡ Π³Π° Π΄ΠΎΠ΄Π°ΡΠΈ Π½Π° Π»ΠΈΡΡΡ.
Π₯Π²Π°Π»Π°.
ΠΠ·Π²ΠΎΡ: Π²Π²Π².Ρ
Π°Π±Ρ.ΡΠΎΠΌ