เบชเบฐเบเบฒเบเบเบต, Habr!
เปเบเบฑเบเปเบงเบฅเบฒเบซเบผเบฒเบเบเบงเปเบฒ 3 เบเบตเบเบตเปเบเปเบญเบเปเบเปเบชเบญเบ SQL เปเบเบชเบนเบเบเบถเบเบญเบปเบเบฎเบปเบกเบเปเบฒเบเป, เปเบฅเบฐเบซเบเบถเปเบเปเบเบเปเปเบชเบฑเบเปเบเบเบเบญเบเบเปเบญเบเปเบกเปเบเบงเปเบฒเบเบฑเบเบฎเบฝเบเบฎเบนเปเปเบฅเบฐเปเบเบปเปเบฒเปเบ SQL เบเบตเบเบงเปเบฒเบเปเบฒเบเบงเบเปเบเบปเบฒเบเบทเบเบกเบญเบเปเบซเป, เปเบฅเบฐเบเปเปเบเบฝเบเปเบเปเบเบญเบเปเบเบดเบเบเบงเบฒเบกเปเบเบฑเบเปเบเปเบเปเปเบฅเบฐเบเบทเปเบเบเบฒเบเบเบดเบเบชเบฐเบเบตเปเบเบปเปเบฒเบเบฑเปเบ.
เปเบเบเบปเบเบเบงเบฒเบกเบเบตเป, เบเปเบฒเบเบฐเปเบเบปเปเบฒเบเบฐเปเบเปเบเบเบฑเบเบเบฑเบเบเปเบฒเบเบเบฑเบเบเบตเบฅเบฒเบเบเบทเปเบเบญเบเบเบฑเบเบซเบฒเบเบญเบเบเปเบฒเบเบฐเปเบเบปเปเบฒเบเบตเปเบเปเบฒเบเบฐเปเบเบปเปเบฒเบกเบญเบเปเบซเปเบเบฑเบเบฎเบฝเบเปเบเบฑเบเบงเบฝเบเบเปเบฒเบเปเบฅเบฐเบเบตเปเบเบงเบเปเบฎเบปเบฒเบเปเบฒเปเบเบตเบเบเบฒเบเบเบฐเปเบเบเบเปเบฒเบเปเบเบญเบเบชเบฐเบซเบกเบญเบ, เปเบเบดเปเบเบเปเบฒเปเบเบชเบนเปเบเบงเบฒเบกเปเบเบปเปเบฒเปเบเปเบฅเบดเบเปเบเบดเปเบเปเบฅเบฐเบเบฑเบเปเบเบเบเปเบฝเบงเบเบฑเบ SQL.
SQL (หษsหkjuหษl; เบเบฒเบชเบฒเบชเบญเบเบเบฒเบกเบเบตเปเบกเบตเปเบเบเบชเปเบฒเบเบเบฒเบชเบฒเบญเบฑเบเบเบดเบ) เปเบกเปเบเบเบฒเบชเบฒเบเบฒเบเบเบฝเบเปเบเบฅเปเบเบฅเบกเบเบฐเบเบฒเบเบเบตเปเปเบเปเปเบเบเบฒเบเบชเปเบฒเบ, เปเบเปเปเบเปเบฅเบฐเบเบฑเบเบเบฒเบเบเปเปเบกเบนเบเปเบเบเบฒเบเบเปเปเบกเบนเบเบเบตเปเบเปเบฝเบงเบเปเบญเบเบเบตเปเบเบธเปเบกเบเบญเบเปเบเบเบฅเบฐเบเบปเบเบเบฒเบเบเบธเปเบกเบเบญเบเบเบฒเบเบเปเปเบกเบนเบเบเบตเปเปเบซเบกเบฒเบฐเบชเบปเบก.
เบเปเบฒเบเบชเบฒเบกเบฒเบเบญเปเบฒเบเบเปเบฝเบงเบเบฑเบ SQL เบเบฒเบเบเปเบฒเบเป
เบเบปเบโเบเบงเบฒเบกโเบเบตเปโเบเปเปโเปเบเปโเบกเบตโเบเบธเบโเบเบฐโเบชเบปเบโเบเบตเปโเบเบฐโเบชเบญเบโเบเปเบฒเบ SQL เบเบฒเบ scratchโ.
เบชเบฐเบเบฑเปเบเปเบซเปเปเบ.
เบเบงเบเปเบฎเบปเบฒเบเบฐเบเปเบฒเปเบเปเบเบตเปเบกเบตเบเบทเปเบชเบฝเบ
เบเปเบฒเบเบฐเปเบเบปเปเบฒเบชเบฑเบเปเบเบเบงเปเบฒเบเบงเบเปเบฎเบปเบฒเบเบฐเบเบดเบเบฒเบฅเบฐเบเบฒเบเบฝเบเปเบเปเบงเบฝเบเบเบฒเบ SELECT. เบเปเปเบกเบตเปเปเบฒเบงเบฝเบ DML เบซเบผเบท DDL เบขเบนเปเบเบตเปเบเบตเป.
เบงเบฝเบเบเบฒเบ
เบเบฒเบเบเบณเบเบฑเบ เปเบฅเบฐเบเบฒเบเบเบฑเบเบฎเบฝเบเบเปเปเบกเบนเบ
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบเปเบฎเบฑเบเบเบฑเบเบเบตเบฅเบฒเบเบเบทเปเบเบตเปเบกเบตเบเปเปเบกเบนเบเบเปเบฝเบงเบเบฑเบเบเบฐเบเบฑเบเบเบฒเบเบเบฑเบเบซเบกเบปเบ
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
SELECT * FROM employees
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบเบฑเบเบเบตเบฅเบฒเบเบเบทเปเบเบญเบเบเบฐเบเบฑเบเบเบฒเบเบเบฑเบเบซเบกเบปเบเบเบตเปเบกเบตเบเบทเป 'David'
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
SELECT *
FROM employees
WHERE first_name = 'David';
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบฅเบฒเบเบเบทเปเบเบฐเบเบฑเบเบเบฒเบเบเบฑเบเปเบปเบเบเบตเปเบกเบต job_id เปเบเบปเปเบฒเบเบฑเบ 'IT_PROG'
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
SELECT *
FROM employees
WHERE job_id = 'IT_PROG'
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เบฎเบฑเบเบชเบฐเปเบฑเบเบเบฐเบเบฑเบเบเบฒเบเบเบฑเบเปเบปเบเบเบฒเบเบเบปเบก 50 (department_id) เบเบตเปเบกเบตเปเบเบดเบเปเบเบทเบญเบ (เปเบเบดเบเปเบเบทเบญเบ) เบซเบผเบฒเบเบเบงเปเบฒ 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;
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบฅเบฒเบเบเบทเปเบเบฐเบเบฑเบเบเบฒเบเบเบฑเบเปเบปเบเบเบตเปเบกเบตเบเบปเบงเบญเบฑเบเบชเบญเบเบชเบธเบเบเปเบฒเบเปเบเบเบทเป 'a'
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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 '';
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบเบฑเบเบเบตเบฅเบฒเบเบเบทเปเบเบญเบ ID เบเบนเปเบเบฑเบเบเบฒเบเบเบฑเบเบซเบกเบปเบ
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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 เบเบปเบงเบญเบฑเบเบชเบญเบ 'a'
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
SELECT *
FROM employees
WHERE INSTR (LOWER (first_name),'a',1,2) > 0;
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบฅเบฒเบเบเบทเปเบเบฐเบเบฑเบเบเบฒเบเบเบฑเบเปเบปเบเบเบตเปเบกเบตเปเบเบดเบเปเบเบทเบญเบเปเบเบฑเบเบเบนเบ 1000
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
SELECT *
FROM employees
WHERE MOD (salary, 1000) = 0;
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบเบปเบงเปเบฅเบ 3 เบเบปเบงเปเบฅเบเบเบณเบญเบดเบเบเบญเบเปเบเบตเปเบเบฅเบฐเบชเบฑเบเบเบญเบเบเบฐเบเบฑเบเบเบฒเบ เบเปเบฒเปเบเบตเปเบเบฅเบฐเบชเบฑเบเบเบญเบเบฅเบฒเบงเบขเบนเปเปเบเบฎเบนเบเปเบเบ XXX.XXX.XXXX
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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';
เบเบฒเบเบฐเบฅเบฒเบ DUAL. เบชเบฐเปเบเบเบงเบฑเบเบเบตเบเบญเบเบกเบทเปเบญเบทเปเบเปเบเบฎเบนเบเปเบเบ: เบกเบทเปเบญเบทเปเบเปเบกเปเบเบงเบฑเบเบเบตเบชเบญเบเบเบญเบเปเบเบทเบญเบเบกเบฑเบเบเบญเบ
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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';
เบเบฒเบเบฐเบฅเบฒเบ 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;
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบฅเบฒเบเบเบทเปเบเบฐเบเบฑเบเบเบฒเบเบเบฑเบเปเบปเบเบเบตเปเบกเบตเปเบเบดเบเปเบเบทเบญเบเปเบเบฑเบก (เปเบเบดเบเปเบเบทเบญเบ + 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;
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบฅเบฒเบเบเบทเปเบเบฐเบเบฑเบเบเบฒเบเบเบฑเบเปเบปเบ เปเบฅเบฐเบเปเปเบกเบนเบเบเปเบฝเบงเบเบฑเบเบเบฒเบเบกเบตเปเบเบดเบเปเบเบเบฑเบ (เปเบกเปเบ/เบเปเป)
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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;
เบฅเบฒเบเบเบฒเบเบเปเปเบกเบนเบเบฅเบงเบกเปเบเบเปเบเปเบซเบเปเบฒเบเบตเปเบเบญเบเบเบธเปเบก
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบเปเบฎเบฑเบเบเบปเบเบฅเบฒเบเบเบฒเบเปเบเบ 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_ids เบเบตเปเบกเบตเบซเบผเบฒเบเบเบงเปเบฒ 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_ids เบเบตเปเบเบฐเบเบฑเบเบเบฒเบเบเบญเบเบซเบผเบฒเบเป (>1) job_ids เปเบฎเบฑเบเบงเบฝเบ
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
SELECT department_id
FROM employees
GROUP BY department_id
HAVING COUNT (DISTINCT job_id) > 1;
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบเบฑเบเบเบตเบฅเบฒเบเบเบทเปเบเบญเบ manager_ids เบเบตเปเบกเบตเบเปเบฒเบเบงเบเบเบนเปเบเปเบญเบเบซเบผเบฒเบเบเบงเปเบฒ 5 เปเบฅเบฐเบเบปเบเบฅเบงเบกเบเบญเบเปเบเบดเบเปเบเบทเบญเบเบเบญเบเบเบนเปเบเปเบญเบเบเบญเบเบฅเบฒเบงเปเบกเปเบเบซเบผเบฒเบเบเบงเปเบฒ 50000.
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
SELECT manager_id
FROM employees
GROUP BY manager_id
HAVING COUNT (*) > 5 AND SUM (salary) > 50000;
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบเปเบฎเบฑเบเบเบฑเบเบเบตเบฅเบฒเบเบเบทเปเบเบญเบ manager_ids เบเบตเปเบกเบตเปเบเบดเบเปเบเบทเบญเบเบชเบฐเปเบฅเปเบเบเบญเบเบเบนเปเบเปเบญเบเบเบฑเบเบซเบกเบปเบเบเบญเบเบฅเบฒเบงเบขเบนเปเปเบเบฅเบฐเบเบฑเบ 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);
เบชเบฐเปเบเบเบเปเปเบกเบนเบเบเบฒเบเบซเบผเบฒเบเบเบฒเบเบฐเบฅเบฒเบเปเบเบเปเบเป Joins
เบเบฐเบเบฑเบเบเบฒเบเบเบฒเบเบฐเบฅเบฒเบ, เบเบฐเปเบเบ, เบชเบฐเบเบฒเบเบเบตเป, เบเบฐเปเบเบ, เบเบฒเบเบเบทเปเบ. เปเบเปเบฎเบฑเบเบเบฑเบเบเบตเบฅเบฒเบเบเบทเปเบเบญเบเบเบฒเบเบเบทเปเบเปเบฅเบฐเบเปเบฒเบเบงเบเบเบญเบเบเบฐเบเบฑเบเบเบฒเบเปเบเปเบเปเบฅเบฐเบเบฒเบเบเบทเปเบ
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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, เบเบปเบก, เบงเบฝเบ, เบเบฐเบซเบเบปเบ, เบเบฐเปเบเบ, เบเบฒเบเบเบทเปเบ
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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 เบเบฐเบเบฑเบเบเบฒเบ subordinate เปเบซเปเปเบเบปเบฒเปเบเบปเปเบฒ
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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. เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบเปเบเบฑเบเบฎเบฑเบเบชเบฒเบเบฐเบเบฑเบเบเบฒเบเบเบฑเบเบซเบกเบปเบ. เบเบฒเบเบฐเบฅเบฒเบ Job_history เปเบเบฑเบเบฎเบฑเบเบชเบฒเบเบฐเบเบฑเบเบเบฒเบเบเบตเปเบญเบญเบเบเบฒเบเบเปเบฅเบดเบชเบฑเบ. เปเบเปโเบฎเบฑเบโเบเบปเบโเบฅเบฒเบโเบเบฒเบโเบเปเบฝเบงโเบเบฑเบโเบเบฐโเบเบฑเบโเบเบฒเบโเบเบฑเบโเบซเบกเบปเบโเปเบฅเบฐโเบชเบฐโเบเบฒโเบเบฐโเบเบฒเบโเบเบญเบโเปเบเบปเบฒโเปเบเบปเปเบฒโเปเบโเบเปโเบฅเบดโเบชเบฑเบ (เปเบฎเบฑเบโเบงเบฝเบโเบซเบผเบทโเบญเบญเบโเบเบฒเบโเบเปโเบฅเบดโเบชเบฑเบโเบเบตเปโเบกเบตโเบงเบฑเบโเบเบตเปโเบญเบญเบโ)
เบเบปเบงเบขเปเบฒเบ:
first_name | เบชเบฐเบเบฒเบเบฐ
เปเบเบเบเบดเปเบเบตเป | เปเบเปเบญเบญเบเบเบฒเบเบเปเบฅเบดเบชเบฑเบเปเบเบงเบฑเบเบเบต 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;
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เบชเบฐเปเบเบเปเบซเปเปเบซเบฑเบเบเบฐเบเบฑเบเบเบฒเบเบเบฑเบเบซเบกเบปเบเบเบตเปเบเปเปเบกเบตเปเบ subordinate เบเบฑเบเปเบเบปเบฒเปเบเบปเปเบฒ
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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.
เบเบปเบงเบขเปเบฒเบ:
เบเบทเป | Job_title | เบเบทเปเบเบฐเปเบเบ
Donald | เบเบฒเบเบเบปเบเบชเบปเปเบ | 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);
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบเบฑเบเบเบตเบฅเบฒเบเบเบทเปเบเบญเบเบเบฐเบเบฑเบเบเบฒเบเบเบตเปเบเบนเปเบเบฑเบเบเบฒเบเปเบเปเบงเบฝเบเปเบเบเบต 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;
เบเบฒเบเบเปเบฒเปเบเป subqueries เปเบเบทเปเบญเปเบเปเปเบเบเปเบฒเบเบฒเบก
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบฅเบฒเบเบเบทเปเบเบฐเบเบฑเบเบเบฒเบเบเบตเปเบกเบตเบเบทเปเบเบฒเบงเบเบตเปเบชเบธเบ.
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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 เบเบฐเบเบฑเบเบเบฒเบ subordinate เปเบซเปเปเบเบปเบฒเปเบเบปเปเบฒ
เบเบฒเบเบเบฑเบเบชเบดเบเปเบ
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.
เบเบปเบงเบขเปเบฒเบ:
เบเบทเป | Job_title | เบเบทเปเบเบฐเปเบเบ
Donald | เบเบฒเบเบเบปเบเบชเบปเปเบ | 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;
เบเบฒเบเบฐเบฅเบฒเบเบเบฐเบเบฑเบเบเบฒเบ. เปเบญเบปเบฒเบเบฑเบเบเบตเบฅเบฒเบเบเบทเปเบเบญเบเบเบฐเบเบฑเบเบเบฒเบเบเบตเปเบเบนเปเบเบฑเบเบเบฒเบเปเบเปเบงเบฝเบเปเบเบเบต 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