เชเชธเช•เซเชฏเซเชเชฒ. เชฎเชจเซ‹เชฐเช‚เชœเช• เช•เซ‹เชฏเชกเชพเช“

เชนเซ‡เชฒเซ‹ เชนเซ‡เชฌเซเชฐ!

3 เชตเชฐเซเชทเชฅเซ€ เชตเชงเซ เชธเชฎเชฏเชฅเซ€ เชนเซเช‚ เชตเชฟเชตเชฟเชง เชคเชพเชฒเซ€เชฎ เช•เซ‡เชจเซเชฆเซเชฐเซ‹เชฎเชพเช‚ SQL เชถเซ€เช–เชตเซ€ เชฐเชนเซเชฏเซ‹ เช›เซเช‚, เช…เชจเซ‡ เชฎเชพเชฐเซเช‚ เชเช• เช…เชตเชฒเซ‹เช•เชจ เช เช›เซ‡ เช•เซ‡ เชœเซ‹ เชตเชฟเชฆเซเชฏเชพเชฐเซเชฅเซ€เช“เชจเซ‡ เช•เซ‹เชˆ เช•เชพเชฐเซเชฏ เชธเซ‹เช‚เชชเชตเชพเชฎเชพเช‚ เช†เชตเซ‡ เชคเซ‹ เชตเชฟเชฆเซเชฏเชพเชฐเซเชฅเซ€เช“ SQL เชจเซ‡ เชตเชงเซ เชธเชพเชฐเซ€ เชฐเซ€เชคเซ‡ เชถเซ€เช–เซ‡ เช›เซ‡ เช…เชจเซ‡ เชธเชฎเชœเซ‡ เช›เซ‡, เช…เชจเซ‡ เชฎเชพเชคเซเชฐ เชถเช•เซเชฏเชคเชพเช“ เช…เชจเซ‡ เชธเซˆเชฆเซเชงเชพเช‚เชคเชฟเช• เชชเชพเชฏเชพ เชตเชฟเชถเซ‡ เชตเชพเชค เช•เชฐเชคเชพ เชจเชฅเซ€.

เช† เชฒเซ‡เช–เชฎเชพเช‚, เชนเซเช‚ เชคเชฎเชพเชฐเซ€ เชธเชพเชฅเซ‡ เชฎเชพเชฐเชพ เช•เชพเชฐเซเชฏเซ‹เชจเซ€ เชธเซ‚เชšเชฟ เชถเซ‡เชฐ เช•เชฐเซ€เชถ เชœเซ‡ เชนเซเช‚ เชตเชฟเชฆเซเชฏเชพเชฐเซเชฅเซ€เช“เชจเซ‡ เชนเซ‹เชฎเชตเชฐเซเช• เชคเชฐเซ€เช•เซ‡ เช†เชชเซเช‚ เช›เซเช‚ เช…เชจเซ‡ เชœเซ‡เชจเชพ เชชเชฐ เช…เชฎเซ‡ เชตเชฟเชตเชฟเชง เชชเซเชฐเช•เชพเชฐเชจเชพ เชตเชฟเชšเชพเชฐ-เชตเชฟเชฎเชฐเซเชถ เช•เชฐเซ€เช เช›เซ€เช, เชœเซ‡ SQL เชจเซ€ เชŠเช‚เชกเซ€ เช…เชจเซ‡ เชธเซเชชเชทเซเชŸ เชธเชฎเชœเชฃ เชคเชฐเชซ เชฆเซ‹เชฐเซ€ เชœเชพเชฏ เช›เซ‡.

เชเชธเช•เซเชฏเซเชเชฒ. เชฎเชจเซ‹เชฐเช‚เชœเช• เช•เซ‹เชฏเชกเชพเช“

SQL (หˆษ›sหˆkjuหˆษ›l; eng. เชธเซเชŸเซเชฐเช•เซเชšเชฐเซเชก เช•เซเชตเซ‡เชฐเซ€ เชฒเซ‡เช‚เช—เซเชตเซ‡เชœ) เช เชฏเซ‹เช—เซเชฏ เชกเซ‡เชŸเชพเชฌเซ‡เช เชฎเซ‡เชจเซ‡เชœเชฎเซ‡เชจเซเชŸ เชธเชฟเชธเซเชŸเชฎ เชฆเซเชตเชพเชฐเชพ เชธเช‚เชšเชพเชฒเชฟเชค เชฐเชฟเชฒเซ‡เชถเชจเชฒ เชกเซ‡เชŸเชพเชฌเซ‡เชเชฎเชพเช‚ เชกเซ‡เชŸเชพ เชฌเชจเชพเชตเชตเชพ, เชธเช‚เชถเซ‹เชงเชฟเชค เช•เชฐเชตเชพ เช…เชจเซ‡ เชฎเซ‡เชจเซ‡เชœ เช•เชฐเชตเชพ เชฎเชพเชŸเซ‡ เชตเชชเชฐเชพเชคเซ€ เช˜เซ‹เชทเชฃเชพเชคเซเชฎเช• เชชเซเชฐเซ‹เช—เซเชฐเชพเชฎเชฟเช‚เช— เชญเชพเชทเชพ เช›เซ‡. เชตเชงเซ เชตเชพเช‚เชšเซ‹โ€ฆ

เชคเชฎเซ‡ เชเชธเช•เซเชฏเซเชเชฒ เชตเชฟเชถเซ‡ เช…เชฒเช—เชฅเซ€ เชตเชพเช‚เชšเซ€ เชถเช•เซ‹ เช›เซ‹ เชธเซเชคเซเชฐเซ‹เชคเซ‹.
เช† เชฒเซ‡เช–เชจเซ‹ เชนเซ‡เชคเซ เชคเชฎเชจเซ‡ เชถเชฐเซ‚เช†เชคเชฅเซ€ SQL เชถเซ€เช–เชตเชตเชพเชจเซ‹ เชจเชฅเซ€.

เชคเซ‹ เชšเชพเชฒเซ‹ เชšเชพเชฒเซ‹.

เช…เชฎเซ‡ เชœเชพเชฃเซ€เชคเชพ เช‰เชชเชฏเซ‹เช— เช•เชฐเซ€เชถเซเช‚ เชเชšเช†เชฐ เชธเซเช•เซ€เชฎ เช“เชฐเซ‡เช•เชฒเชฎเชพเช‚ เชคเซ‡เชจเชพ เช•เซ‹เชทเซเชŸเช•เซ‹ เชธเชพเชฅเซ‡ (เชตเชงเซ เชตเชพเช‚เชšเซ‹):

เชเชธเช•เซเชฏเซเชเชฒ. เชฎเชจเซ‹เชฐเช‚เชœเช• เช•เซ‹เชฏเชกเชพเช“
เชนเซเช‚ เชจเซ‹เช‚เชงเซเช‚ เช›เซเช‚ เช•เซ‡ เช…เชฎเซ‡ เชซเช•เซเชค SELECT เชชเชฐเชจเชพ เช•เชพเชฐเซเชฏเซ‹เชจเซ‡ เชœ เชงเซเชฏเชพเชจเชฎเชพเช‚ เชฒเชˆเชถเซเช‚. DML เช…เชจเซ‡ DDL เชชเชฐ เช•เซ‹เชˆ เช•เชพเชฐเซเชฏเซ‹ เชจเชฅเซ€.

เช•เชพเชฐเซเชฏเซ‹

เชกเซ‡เชŸเชพเชจเซ‡ เชชเซเชฐเชคเชฟเชฌเช‚เชงเชฟเชค เช…เชจเซ‡ เชตเชฐเซเช—เซ€เช•เชฐเชฃ

เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซเช‚ เชŸเซ‡เชฌเชฒ. เชฌเชงเชพ เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“ เชตเชฟเชถเซ‡ เชฎเชพเชนเชฟเชคเซ€ เชธเชพเชฅเซ‡ เชฏเชพเชฆเซ€ เชฎเซ‡เชณเชตเซ‹
เชจเชฟเชฐเซเชฃเชฏ

SELECT * FROM employees

เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซเช‚ เชŸเซ‡เชฌเชฒ. 'เชกเซ‡เชตเชฟเชก' เชจเชพเชฎเชจเชพ เชคเชฎเชพเชฎ เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซ€ เชฏเชพเชฆเซ€ เชฎเซ‡เชณเชตเซ‹
เชจเชฟเชฐเซเชฃเชฏ

SELECT *
  FROM employees
 WHERE first_name = 'David';

เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซเช‚ เชŸเซ‡เชฌเชฒ. 'IT_PROG' เชธเชฎเชพเชจ job_id เชงเชฐเชพเชตเชคเชพ เชคเชฎเชพเชฎ เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซ€ เชฏเชพเชฆเซ€ เชฎเซ‡เชณเชตเซ‹
เชจเชฟเชฐเซเชฃเชฏ

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เชฎเชพ เชตเชฟเชญเชพเช— (เชกเชฟเชชเชพเชฐเซเชŸเชฎเซ‡เชจเซเชŸ_เช†เชˆเชกเซ€) เชจเชพ เชคเชฎเชพเชฎ เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซ€ เชฏเชพเชฆเซ€ เชฎเซ‡เชณเชตเซ‹ เช•เซ‡ เชœเซ‡เชฎเชจเซ€ เชชเชพเชธเซ‡ เชฌเซ‹เชจเชธ เช›เซ‡ (เช•เชฎเชฟเชถเชจ_เชชเซ€เชธเซ€เชŸเซ€ เช•เซ‰เชฒเชฎเชฎเชพเช‚ เชฎเซ‚เชฒเซเชฏ เช–เชพเชฒเซ€ เชจเชฅเซ€)
เชจเชฟเชฐเซเชฃเชฏ

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;

เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซเช‚ เชŸเซ‡เชฌเชฒ. เชซเซ‹เชฐเซเชฎเซ‡เชŸเชฎเชพเช‚ เชคเซ‡เชฎเชจเซ€ เชธเซเชฅเชฟเชคเชฟ เชงเชฐเชพเชตเชคเชพ เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซ€ เชฏเชพเชฆเซ€ เชฎเซ‡เชณเชตเซ‹: เชกเซ‹เชจเชพเชฒเซเชก(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-เช…เช‚เช•เชจเซ‹ เชจเช‚เชฌเชฐ เชฎเซ‡เชณเชตเซ‹ เชœเซ‹ เชคเซ‡เชจเซ‹ เชจเช‚เชฌเชฐ ะฅะฅะฅ.ะฅะฅะฅ.ะฅะฅะฅะฅ เชซเซ‹เชฐเซเชฎเซ‡เชŸเชฎเชพเช‚ เชนเซ‹เชฏ
เชจเชฟเชฐเซเชฃเชฏ

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;

เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซเช‚ เชŸเซ‡เชฌเชฒ. เชเชตเชพ เชคเชฎเชพเชฎ เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซ€ เชฏเชพเชฆเซ€ เชฎเซ‡เชณเชตเซ‹ เช•เซ‡ เชœเซ‡เชฎเชจเชพ '_' เชšเชฟเชนเซเชจ เชชเช›เซ€ เชจเซ‹เช•เชฐเซ€_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-เช†เชซเซเชฐเชฟเช•เชพ (เชœเซ‹เชกเชพเชฏเชพ เชตเชฟเชจเชพ)
เชจเชฟเชฐเซเชฃเชฏ

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;

เชฆเซ‡เชถเซ‹เชจเซเช‚ เชŸเซ‡เชฌเชฒ. เชคเชฎเชพเชฎ เชฆเซ‡เชถเชจเชพ_เชจเชพเชฎเซ‹เชจเชพ เชคเชฎเชพเชฎ เช…เช•เซเชทเชฐเซ‹เชจเชพ เชชเซเชฐเชฆเซ‡เชถ_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;

เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซเช‚ เชŸเซ‡เชฌเชฒ. '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;

เช•เซ‹เชทเซเชŸเช• เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“, เชตเชฟเชญเชพเช—เซ‹, เชธเซเชฅเชพเชจเซ‹, เชฆเซ‡เชถเซ‹, เชชเซเชฐเชฆเซ‡เชถเซ‹. เชฆเชฐเซ‡เช• เช•เชฐเซเชฎเชšเชพเชฐเซ€ เชตเชฟเชถเซ‡ เชตเชฟเช—เชคเชตเชพเชฐ เชฎเชพเชนเชฟเชคเซ€ เชฎเซ‡เชณเชตเซ‹:
เชชเซเชฐเชฅเชฎ_เชจเชพเชฎ, เช›เซ‡เชฒเซเชฒเซเช‚_เชจเชพเชฎ, เชตเชฟเชญเชพเช—, เชจเซ‹เช•เชฐเซ€, เชถเซ‡เชฐเซ€, เชฆเซ‡เชถ, เชชเซเชฐเชฆเซ‡เชถ
เชจเชฟเชฐเซเชฃเชฏ

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;

เชŸเซ‡เชฌเชฒ เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“, เชจเซ‹เช•เชฐเซ€เช“, เชตเชฟเชญเชพเช—เซ‹. เช•เชฐเซเชฎเชšเชพเชฐเซ€เช“เชจเซ‡ เชซเซ‹เชฐเซเชฎเซ‡เชŸเชฎเชพเช‚ เชฌเชคเชพเชตเซ‹: 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

เชเช• เชŸเชฟเชชเซเชชเชฃเซ€ เช‰เชฎเซ‡เชฐเซ‹