๋ณธ๋ฌธ ๋ฐ”๋กœ๊ฐ€๊ธฐ
ORACLE/SQL

[ORACLE] SELECT ๋ช…๋ น์–ด ๊ธฐ๋ณธ ์‚ฌ์šฉ :: ๋งˆ์ด์ž๋ชฝ

by ๐ŸŒปโ™š 2019. 9. 8.

ORACLE SELECT ๋ช…๋ น์–ด ๊ธฐ๋ณธ ์‚ฌ์šฉ

SQL Query๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค์—์„œ ํ™•์ธํ•˜๊ณ  ์‹ถ์€ ๋ฐ์ดํ„ฐ๋ฅผ ์›ํ•˜๋Š” ํ˜•ํƒœ๋กœ ๋ณด๊ธฐ์œ„ํ•ด์„œ๋Š” SELECT ๋ช…๋ น์–ด๋ฅผ ์•Œ์•„์•ผํ•œ๋‹ค. SELECT ๋ช…๋ น์–ด๋Š” CRUD์—์„œ 'R'์— ํ•ด๋‹นํ•˜๋Š” READ๋ถ€๋ถ„์œผ๋กœ ๋ฐ์ดํ„ฐ๋ฅผ ์ฝ์„๋•Œ ์‚ฌ์šฉํ•˜๋ฉด ๋œ๋‹ค.

ํ•ด๋‹น๊ธ€์—์„œ๋Š” Oracle 11g ๋ฒ„์ „์„ ์‚ฌ์šฉํ•˜๊ณ  HR๊ณ„์ •์˜ ๊ธฐ๋ณธ ํ…Œ์ด๋ธ”์„ ์‚ฌ์šฉํ•˜์—ฌ ์‹ค์Šตํ–ˆ์Šต๋‹ˆ๋‹ค.



TAB

TAB์„ ์กฐํšŒํ•˜์—ฌ ์ ‘์†ํ•œ ๊ณ„์ •์ด ์†Œ์œ ํ•˜๊ณ  ์žˆ๋Š” ํ…Œ์ด๋ธ”์„ ํ™•์ธํ•  ์ˆ˜ ์žˆ๋‹ค.

QUERY

1
SELECT * FROM TAB;
cs


RESULT




DESC

DESC ๋ช…๋ น์„ ์‚ฌ์šฉํ•˜์—ฌ ํ•ด๋‹น ํ…Œ์ด๋ธ”์˜ ์ •๋ณด๋ฅผ ์†์„ฑ ๋ฐ ํƒ€์ž…์„ ๊ฐ„๋žตํ•˜๊ฒŒ ํ™•์ธํ•  ์ˆ˜ ์žˆ๋‹ค.


๋ช…๋ น : DESC [ํ…Œ์ด๋ธ”];


QUERY

EMPLOYEES ํ…Œ์ด๋ธ”์˜ ์ •๋ณด๋ฅผ ํ™•์ธํ•œ๋‹ค.
1
DESC EMPLOYEES;
cs


RESULT




์ „์ฒด ํ•„๋“œ SELECT

SELECT ๋ช…๋ น์–ด์™€ ํ•ด๋‹น ํ…Œ์ด๋ธ”์˜ ์ „์ฒด ํ•„๋“œ๋ฅผ ํ™•์ธํ•˜๋Š” '*' ๋ฌธ์ž๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ํ…Œ์ด๋ธ”์˜ ์ „์ฒด ํ•„๋“œ์™€ ๋ฐ์ดํ„ฐ๋ฅผ ํ™•์ธํ•œ๋‹ค.
๋ช…๋ น : SELECT * FROM [ํ…Œ์ด๋ธ”];

QUERY

EMPLOYEES ํ…Œ์ด๋ธ”์˜ ์ „์ฒด ํ•„๋“œ ๋ฐ์ดํ„ฐ๋ฅผ ์ฝ๋Š”๋‹ค.
1
SELECT * FROM EMPLOYEES;
cs

RESULT




ํŠน์ • ํ•„๋“œ ์„ ํƒํ•˜์—ฌ SELECT

SELECT ๋ช…๋ น์–ด์™€ ์ฝ๊ณ ์‹ถ์€ ํ•„๋“œ๋ฅผ ๋‚˜์—ดํ•˜์—ฌ ๋ฐ์ดํ„ฐ๋ฅผ ํ™•์ธํ•œ๋‹ค.
๋ช…๋ น : SELECT [ํ•„๋“œ1], [ํ•„๋“œ2], [ํ•„๋“œ3] ... FROM [ํ…Œ์ด๋ธ”];

QUERY

EMPLOYEESํ…Œ์ด๋ธ”์˜ EMPLOYEE_ID, LAST_NAME, FIRST_NAME ํ•„๋“œ๊ฐ’์„ ์ฝ๋Š”๋‹ค.
1
SELECT EMPLOYEE_ID, LAST_NAME, FIRST_NAME FROM EMPLOYEES;
cs

RESULT




๋ณ„์นญ(ALIAS) ์‚ฌ์šฉํ•˜์—ฌ SELECT AS

ํ•„๋“œ๊ฐ’์— ๋ณ„์นญ์„ ์‚ฌ์šฉํ•˜์—ฌ ๊ฒฐ๊ณผ์ถœ๋ ฅ์„ ํ•  ์ˆ˜ ์žˆ๋‹ค.

๋ณ„์นญ์„ ์‚ฌ์šฉํ• ๋•Œ๋Š” ํฐ๋”ฐ์˜ดํ‘œ""๋กœ ๊ฐ์‹ธ๊ฑฐ๋‚˜ ๋นผ๊ณ  ๋ช…๋ น์„ ํ•ด๋„ ๋œ๋‹ค.

๋ช…๋ น : SELECT [ํ•„๋“œ1] AS [๋ณ„์นญ1], [ํ•„๋“œ1] AS [๋ณ„์นญ1], [ํ•„๋“œ1] AS [๋ณ„์นญ1] ... FROM [ํ…Œ์ด๋ธ”];


QUERY

๊ฐ ํ•„๋“œ์— ๋ณ„์นญ์„ ๋ถ€์—ฌํ•˜์—ฌ ๋ฐ์ดํ„ฐ๋ฅผ ํ™•์ธํ•œ๋‹ค.
1
SELECT EMPLOYEE_ID AS "์ข…์—…์›ID", LAST_NAME AS "์„ฑ", FIRST_NAME AS "์ด๋ฆ„" FROM EMPLOYEES;
cs

RESULT




์ค‘๋ณต์ œ๊ฑฐ DISTINCT

์ค‘๋ณต๋œ ๋ฐ์ดํ„ฐ๊ฐ€ ์žˆ๋‹ค๋ฉด ํ•˜๋‚˜๋กœ ๋ณด๊ณ ์‹ถ์„๋•Œ ์‚ฌ์šฉํ•œ๋‹ค.

ํ•„๋“œ๊ฐ’์„ ์—ฌ๋Ÿฌ๊ฐœ ์‚ฌ์šฉํ•œ๋‹ค๋ฉด ํ•ด๋‹น ํ•„๋“œ๊ฐ€ ํ•จ๊ป˜ ๊ณ ์œ ํ•œ ๊ฐ’์„ ๋ณด์—ฌ์ค€๋‹ค.

๋ช…๋ น : SELECT DISTINCT [์†์„ฑ1], [์†์„ฑ2] ... FROM [ํ…Œ์ด๋ธ”];


QUERY

JOB_ID ์ค‘๋ณต์ œ๊ฑฐํ•˜๊ณ  ๋ฐ์ดํ„ฐ๋ฅผ ๋ณด์—ฌ์ค€๋‹ค.
๋งŒ์•ฝ ํ•„๋“œ๊ฐ’์„ ๋‘๊ฐœ ์ด์ƒ EX(JOB_ID, FIRST_NAME)์œผ๋กœ ์ง€์ •ํ•œ๋‹ค๋ฉด
JOB_ID ์™€ FIRST_NAME์„ ๊ฐ™์ด ํฌํ•จํ•ด์„œ ์ค‘๋ณต์„ ์ œ๊ฑฐํ•œ ๋ฐ์ดํ„ฐ๋ฅผ ๋ณด์—ฌ์ค€๋‹ค.
1
SELECT DISTINCT JOB_ID FROM EMPLOYEES;
cs

RESULT




๋Œ“๊ธ€