์๋ ํ๋ธ๋ฅด!
์ ๋ 3๋ ์ด์ ๋ค์ํ ๊ต์ก ์ผํฐ์์ SQL์ ๊ฐ๋ฅด์น๊ณ ์์ผ๋ฉฐ ์ ๊ฐ ๊ด์ฐฐํ ๊ฒ ์ค ํ๋๋ ํ์๋ค์ด ๊ฐ๋ฅ์ฑ๊ณผ ์ด๋ก ์ ํ ๋์ ๋ํด์๋ง ์ด์ผ๊ธฐํ๋ ๊ฒ์ด ์๋๋ผ ๊ณผ์ ๊ฐ ์ฃผ์ด์ง๋ฉด SQL์ ๋ ์ ๋ง์คํฐํ๊ณ ์ดํดํ๋ค๋ ๊ฒ์ ๋๋ค.
์ด ๊ธฐ์ฌ์์๋ ํ์๋ค์๊ฒ ์์ ๋ก ์ ๊ณตํ๊ณ SQL์ ๋ํ ๊น๊ณ ๋ช ํํ ์ดํด๋ก ์ด์ด์ง๋ ๋ค์ํ ์ข ๋ฅ์ ๋ธ๋ ์ธ์คํ ๋ฐ์ ์ํํ๋ ์์ ๋ชฉ๋ก์ ์ฌ๋ฌ๋ถ๊ณผ ๊ณต์ ํ ๊ฒ์ ๋๋ค.
SQL(หษsหkjuหษl; eng. ๊ตฌ์กฐ์ ์ฟผ๋ฆฌ ์ธ์ด)์ ์ ์ ํ ๋ฐ์ดํฐ๋ฒ ์ด์ค ๊ด๋ฆฌ ์์คํ
์ ์ํด ๊ด๋ฆฌ๋๋ ๊ด๊ณํ ๋ฐ์ดํฐ๋ฒ ์ด์ค์์ ๋ฐ์ดํฐ๋ฅผ ์์ฑ, ์์ ๋ฐ ๊ด๋ฆฌํ๋ ๋ฐ ์ฌ์ฉ๋๋ ์ ์ธ์ ํ๋ก๊ทธ๋๋ฐ ์ธ์ด์
๋๋ค.
๋ค๋ฅธ ๊ณณ์์ SQL์ ๋ํด ์ฝ์ ์ ์์ต๋๋ค.
์ด ๊ธฐ์ฌ๋ SQL์ ์ฒ์๋ถํฐ ๊ฐ๋ฅด์น๊ธฐ ์ํ ๊ฒ์ด ์๋๋๋ค.
์, ๊ฐ์.
์ฐ๋ฆฌ๋ ์ ์๋ ค์ง ๊ฒ์ ์ฌ์ฉํ ๊ฒ์
๋๋ค
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๋ณด๋ค ํฐ 4000๋ฒ์งธ ๋ถ์(department_id)์ ๋ชจ๋ ์ง์ ๋ชฉ๋ก ๊ฐ์ ธ์ค๊ธฐ
๊ฒฐ์
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;
์ง์ ํ
์ด๋ธ. ์ด๋ฆ์ 'n'์ด 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 '';
์ง์ ํ
์ด๋ธ. ๋ชจ๋ ๊ด๋ฆฌ์ 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;
์ง์ ํ
์ด๋ธ. ์ด๋ฆ์ 'a'๊ฐ 2๊ฐ ์ด์ ํฌํจ๋ ๋ชจ๋ ์ง์์ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
SELECT *
FROM employees
WHERE INSTR (LOWER (first_name),'a',1,2) > 0;
์ง์ ํ
์ด๋ธ. ๊ธ์ฌ๊ฐ 1000์ ๋ฐฐ์์ธ ๋ชจ๋ ์ง์ ๋ชฉ๋ก ๊ฐ์ ธ์ค๊ธฐ
๊ฒฐ์
SELECT *
FROM employees
WHERE MOD (salary, 1000) = 0;
์ง์ ํ
์ด๋ธ. ๋ฒํธ๊ฐ ะฅะฅะฅ.ะฅะฅะฅ.ะฅะฅะฅะฅ ํ์์ธ ๊ฒฝ์ฐ ์ง์ ์ ํ ๋ฒํธ์ ์ฒซ 3์๋ฆฌ ์ซ์๋ฅผ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
SELECT phone_number, SUBSTR (phone_number, 1, 3) new_phone_number
FROM employees
WHERE phone_number LIKE '___.___.____';
๋ถ์ ํ
์ด๋ธ. ์ด๋ฆ์ ๋ ๋จ์ด ์ด์์ธ ๊ฒฝ์ฐ ๋ถ์ ์ด๋ฆ์์ ์ฒซ ๋จ์ด ๊ฐ์ ธ ์ค๊ธฐ
๊ฒฐ์
SELECT department_name,
SUBSTR (department_name, 1, INSTR (department_name, ' ')-1)
first_word
FROM departments
WHERE INSTR (department_name, ' ') > 0;
์ง์ ํ
์ด๋ธ. ์ด๋ฆ์ ์ฒซ ๊ธ์์ ๋ง์ง๋ง ๊ธ์ ์์ด ์ง์ ์ด๋ฆ ๊ฐ์ ธ์ค๊ธฐ
๊ฒฐ์
SELECT first_name, SUBSTR (first_name, 2, LENGTH (first_name) - 2) new_name
FROM employees;
์ง์ ํ
์ด๋ธ. ์ด๋ฆ์ ๋ง์ง๋ง ๋ฌธ์๊ฐ 'm'์ด๊ณ ์ด๋ฆ์ ๊ธธ์ด๊ฐ 5๋ณด๋ค ํฐ ๋ชจ๋ ์ง์์ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
SELECT *
FROM employees
WHERE SUBSTR (first_name, -1) = 'm' AND LENGTH(first_name)>5;
๋์ผ ํ
์ด๋ธ. ๋ค์์ฃผ ๊ธ์์ผ ๋ ์ง ๊ตฌํ๊ธฐ
๊ฒฐ์
SELECT NEXT_DAY (SYSDATE, 'FRIDAY') next_friday FROM DUAL;
์ง์ ํ
์ด๋ธ. 17๋
์ด์ ํ์ฌ์ ๊ทผ๋ฌดํ ๋ชจ๋ ์ง์ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
SELECT *
FROM employees
WHERE MONTHS_BETWEEN (SYSDATE, hire_date) / 12 > 17;
์ง์ ํ
์ด๋ธ. ์ ํ๋ฒํธ์ ๋ง์ง๋ง ์๋ฆฌ๊ฐ ํ์์ด๊ณ ์ ์ผ๋ก ๊ตฌ๋ถ๋ 3๊ฐ์ ์ซ์๋ก ๊ตฌ์ฑ๋ ๋ชจ๋ ์ง์์ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
SELECT *
FROM employees
WHERE MOD (SUBSTR (phone_number, -1), 2) != 0
AND INSTR (phone_number,'.',1,3) = 0;
์ง์ ํ
์ด๋ธ. '_' ๊ธฐํธ ๋ค์ job_id ๊ฐ์ด 3์ ์ด์์ด์ง๋ง '_' ๋ค์ ์ด ๊ฐ์ด 'CLERK'์ ๊ฐ์ง ์์ ๋ชจ๋ ์ง์์ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
SELECT *
FROM employees
WHERE LENGTH (SUBSTR (job_id, INSTR (job_id, '_') + 1)) > 3
AND SUBSTR (job_id, INSTR (job_id, '_') + 1) != 'CLERK';
์ง์ ํ
์ด๋ธ. PHONE_NUMBER ๊ฐ์์ '.'์ ๋ชจ๋ ๊ต์ฒดํ์ฌ ๋ชจ๋ ์ง์ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค. ์ '-'
๊ฒฐ์
SELECT phone_number, REPLACE (phone_number, '.', '-') new_phone_number
FROM employees;
๋ณํ ํจ์ ๋ฐ ์กฐ๊ฑด์ ์ฌ์ฉ
์ง์ ํ
์ด๋ธ. ๋งค์ XNUMX์ผ์ ์ถ๊ทผํ ๋ชจ๋ ์ง์ ๋ชฉ๋ก ๊ฐ์ ธ์ค๊ธฐ(์์)
๊ฒฐ์
SELECT *
FROM employees
WHERE TO_CHAR (hire_date, 'DD') = '01';
์ง์ ํ
์ด๋ธ. 2008๋
์ ์ถ๊ทผํ ๋ชจ๋ ์ง์์ ๋ชฉ๋ก์ ๋ฐ์ผ์ญ์์ค.
๊ฒฐ์
SELECT *
FROM employees
WHERE TO_CHAR (hire_date, 'YYYY') = '2008';
๋์ผ ํ
์ด๋ธ. ๋ด์ผ ๋ ์ง๋ฅผ ๋ค์ ํ์์ผ๋ก ํ์: Tomorrow is Second day of January
๊ฒฐ์
SELECT TO_CHAR (SYSDATE, 'fm""Tomorrow is ""Ddspth ""day of"" Month') info
FROM DUAL;
์ง์ ํ
์ด๋ธ. 21๋
2007์ XNUMX์ผ ํ์์ ๋ชจ๋ ์ง์ ๋ฐ ์์ ๋ ์ง ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
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๋
XNUMX์์ ์ถ๊ทผํ ๋ชจ๋ ์ง์์ ๋ชฉ๋ก์ ๋ฐ์ผ์ญ์์ค.
๊ฒฐ์
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;
๊ทธ๋ฃน ๊ธฐ๋ฅ์ ์ฌ์ฉํ์ฌ ์ง๊ณ๋ ๋ฐ์ดํฐ ๋ณด๊ณ
์ง์ ํ
์ด๋ธ. ์ต์ ๋ฐ ์ต๋ ๊ธ์ฌ, ์กฐ๊ธฐ ๋์ฐฉ ๋ฐ ์ง์ฐ ๋์ฐฉ ๋ ์ง, ์ง์ ์์ ํจ๊ป department_id๋ณ๋ก ๋ณด๊ณ ์๋ฅผ ๊ฐ์ ธ์ต๋๋ค. ์ง์ ์๋ก ์ ๋ ฌ(desc)
๊ฒฐ์
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๋ช
์ด์์ธ department_id ๋ชฉ๋ก ๊ฐ์ ธ์ค๊ธฐ
๊ฒฐ์
SELECT department_id
FROM employees
GROUP BY department_id
HAVING COUNT (*) > 30;
์ง์ ํ
์ด๋ธ. ๋ถ์_ID ๋ชฉ๋ก๊ณผ ๊ฐ ๋ถ์ ์ง์์ ๋ฐ์ฌ๋ฆผ๋ ํ๊ท ๊ธ์ฌ๋ฅผ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
SELECT department_id, ROUND (AVG (salary)) avg_salary
FROM employees
GROUP BY department_id;
๊ตญ๊ฐ ํ
์ด๋ธ. 60๊ฐ ์ด์์ ๋ชจ๋ country_names์ ๋ชจ๋ ๋ฌธ์์ region_id ํฉ๊ณ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
SELECT region_id
FROM countries
GROUP BY region_id
HAVING SUM (LENGTH (country_name)) > 60;
์ง์ ํ
์ด๋ธ. ์ฌ๋ฌ(>1) job_id์ ์ง์์ด ๊ทผ๋ฌดํ๋ department_id ๋ชฉ๋ก ๊ฐ์ ธ์ค๊ธฐ
๊ฒฐ์
SELECT department_id
FROM employees
GROUP BY department_id
HAVING COUNT (DISTINCT job_id) > 1;
์ง์ ํ
์ด๋ธ. ๋ถํ ์ง์์ ์๊ฐ 5๋ณด๋ค ํฌ๊ณ ๋ถํ ์ง์์ ๋ชจ๋ ๊ธ์ฌ ํฉ๊ณ๊ฐ 50000๋ณด๋ค ํฐ manager_id์ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
SELECT manager_id
FROM employees
GROUP BY manager_id
HAVING COUNT (*) > 5 AND SUM (salary) > 50000;
์ง์ ํ
์ด๋ธ. ๋ชจ๋ ๋ถํ ์ง์์ ํ๊ท ๊ธ์ฌ๊ฐ 6000์์ 9000 ์ฌ์ด์ด๊ณ ๋ณด๋์ค๋ฅผ ๋ฐ์ง ์๋ manager_id ๋ชฉ๋ก ๊ฐ์ ธ์ค๊ธฐ(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;
์ง์ ํ
์ด๋ธ. 'CLERK'๋ผ๋ ๋จ์ด๋ก ๋๋๋ ๋ชจ๋ ์ง์ job_id์์ ์ต๋ ๊ธ์ฌ๋ฅผ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
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;
์ง์ ํ
์ด๋ธ, Job_history. Employee ํ
์ด๋ธ์ ๋ชจ๋ ์ง์์ ์ ์ฅํฉ๋๋ค. Job_history ํ
์ด๋ธ์ ํด์ฌํ ์ง์์ ์ ์ฅํฉ๋๋ค. ๋ชจ๋ ์ง์ ๋ฐ ํ์ฌ ๋ด ์ํ์ ๋ํ ๋ณด๊ณ ์ ๋ฐ๊ธฐ (ํด์ฌ ๋ ์ง๋ก ํ์ฌ๋ฅผ ๋ ๋๊ฑฐ๋ ํด์ฌ)
์ :
์ด๋ฆ | ์ํ
์ ๋ํผ | 31๋
2006์ XNUMX์ผ ํด์ฌ
ํด๋ผ๋ผ | ํ์ฌ ์ผํ๊ณ ์์
๊ฒฐ์
SELECT first_name,
NVL2 (
end_date,
TO_CHAR (end_date, 'fm""Left the company at"" DD ""of"" Month, YYYY'),
'Currently Working')
status
FROM employees e LEFT JOIN job_history j ON (e.employee_id = j.employee_id);
ํ
์ด๋ธ ์ง์, ๋ถ์, ์์น, ๊ตญ๊ฐ, ์ง์ญ. ์ ๋ฝ(region_name)์ ๊ฑฐ์ฃผํ๋ ์ง์ ๋ชฉ๋ก ๊ฐ์ ธ์ค๊ธฐ
๊ฒฐ์
SELECT first_name
FROM employees
JOIN departments USING (department_id)
JOIN locations USING (location_id)
JOIN countries USING (country_id)
JOIN regions USING (region_id)
WHERE region_name = 'Europe';
SELECT first_name
FROM employees e
JOIN departments d ON (e.department_id = d.department_id)
JOIN locations l ON (d.location_id = l.location_id)
JOIN countries c ON (l.country_id = c.country_id)
JOIN regions r ON (c.region_id = r.region_id)
WHERE region_name = 'Europe';
ํ
์ด๋ธ ์ง์, ๋ถ์. ์ง์์ด 30๋ช
์ด์์ธ ๋ชจ๋ ๋ถ์ ํ์
๊ฒฐ์
SELECT department_name, COUNT (*)
FROM employees e JOIN departments d ON (e.department_id = d.department_id)
GROUP BY department_name
HAVING COUNT (*) > 30;
ํ
์ด๋ธ ์ง์, ๋ถ์. ๋ถ์์ ์ํ์ง ์์ ๋ชจ๋ ์ง์ ํ์
๊ฒฐ์
SELECT first_name
FROM employees e
LEFT JOIN departments d ON (e.department_id = d.department_id)
WHERE d.department_name IS NULL;
SELECT first_name
FROM employees
WHERE department_id IS NULL;
ํ
์ด๋ธ ์ง์, ๋ถ์. ์ง์์ด ์๋ ๋ชจ๋ ๋ถ์ ํ์
๊ฒฐ์
SELECT department_name
FROM employees e
RIGHT JOIN departments d ON (e.department_id = d.department_id)
WHERE first_name IS NULL;
์ง์ ํ
์ด๋ธ. ๋ถํ ์ง์์ด ์๋ ๋ชจ๋ ์ง์ ํ์
๊ฒฐ์
SELECT man.first_name
FROM employees emp
RIGHT JOIN employees man ON (emp.manager_id = man.employee_id)
WHERE emp.FIRST_NAME IS NULL;
ํ
์ด๋ธ ์ง์, ์์
, ๋ถ์. First_name, Job_title, Department_name ํ์์ผ๋ก ์ง์์ ํ์ํฉ๋๋ค.
์ :
์ด๋ฆ | ์ง์ | ๋ถ์ ์ด๋ฆ
๋๋๋ | ๋ฐฐ์ก | ์ ์ ๋ฐฐ์ก
๊ฒฐ์
SELECT first_name, job_title, department_name
FROM employees e
JOIN jobs j ON (e.job_id = j.job_id)
JOIN departments d ON (d.department_id = e.department_id);
์ง์ ํ
์ด๋ธ. ๊ด๋ฆฌ์๊ฐ 2005๋
์ ์ผ์๋ฆฌ๋ฅผ ์ป์์ง๋ง ๋์์ ์ด ๊ทผ๋ก์ ์์ ๋ 2005๋
์ด์ ์ ์ผ์๋ฆฌ๋ฅผ ์ป์ ์ง์ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
SELECT emp.*
FROM employees emp JOIN employees man ON (emp.manager_id = man.employee_id)
WHERE TO_CHAR (man.hire_date, 'YYYY') = '2005'
AND emp.hire_date < TO_DATE ('01012005', 'DDMMYYYY');
์ง์ ํ
์ด๋ธ. ๊ด๋ฆฌ์๊ฐ 15์์ ์ผ์๋ฆฌ๋ฅผ ์ป์๊ณ ์ด ์ง์์ job_title ๊ธธ์ด๊ฐ XNUMX์ ์ด์์ธ ์ง์ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
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์์ ์ผ์๋ฆฌ๋ฅผ ์ป์๊ณ ์ด ์ง์์ job_title ๊ธธ์ด๊ฐ XNUMX์ ์ด์์ธ ์ง์ ๋ชฉ๋ก์ ๊ฐ์ ธ์ต๋๋ค.
๊ฒฐ์
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์์ ํฅ๋ฏธ๋ก์ด ์์ ์ ์ ์ํ๋ฉด ๋๊ธ์ ์์ฑํด ์ฃผ์๋ฉด ๋ชฉ๋ก์ ์ถ๊ฐํ๊ฒ ์ต๋๋ค.
๊ฐ์ฌํฉ๋๋ค.
์ถ์ฒ : habr.com