Notice
Recent Posts
Recent Comments
관리 메뉴

Developer Gonie

[6주차] 28. PL/SQL언어, SELECT into from쿼리(결과가 1개 행만 나오는 쿼리에서 값을 가져올 수 있음) 본문

K-DigitalTraining 강의/2. Oracle + PLSQL

[6주차] 28. PL/SQL언어, SELECT into from쿼리(결과가 1개 행만 나오는 쿼리에서 값을 가져올 수 있음)

이대곤 2022. 6. 16. 16:50

* 주의, select ~ into구문은 쿼리문의 결과가 1줄만 나오는 경우에만 사용이 가능하다. 

* PL/SQL 에서는 한 번에 모두를 읽어오는 기능은 없고, 한 줄 씩만 읽어오는게 가능하다.

* 조회된 결과를 받아올 변수는 컬럼의 타입과 일치해야 한다.

기본예제

--바로 아래의 쿼리문의 결과에서 값을 가져오는 방법이다.
select name, position, salary
from company
where sabun=3;

NAME                     POSITION                 SALARY
------------------------ -------------------- ----------
찬열                     과장                       3000
-------------------------------------------------------


declare
	vname varchar2(12);		-- 타입은 가져온 값과 일치해야 한다.
	vposition varchar2(12);		-- 타입은 가져온 값과 일치해야 한다.
	vsalary number; 		-- 타입은 가져온 값과 일치해야 한다.
begin
	select name, position, salary	-- 테이블에서 조회할 컬럼 선택
	into vname, vposition, vsalary	-- 조회된 결과를 받아올 변수 
	from company
	where sabun=3;
    
	dbms_output.put_line(vname || ',' || vposition || ',' || vsalary);
end;
/

찬열,과장,3000

PL/SQL 처리가 정상적으로 완료되었습니다.

--바로 아래의 쿼리문의 결과에서 값을 가져오는 방법이다.
select max(salary), avg(salary)
from company;

MAX(SALARY) AVG(SALARY)
----------- -----------
       9000        4500
-------------------------------------------------------


declare
	vsalary number;
	vavg number;
begin

	select max(salary), avg(salary)
	into vsalary, vavg
	from company;
    
	dbms_output.put_line('최고급여: ' || vsalary);
	dbms_output.put_line('평균급여: ' || vavg);
end;
/

최고급여: 9000
평균급여: 4500

PL/SQL 처리가 정상적으로 완료되었습니다.

--바로 아래의 쿼리문의 결과에서 값을 가져오는 방법이다.
select depart, avg(salary)
from members
group by depart
having avg(salary) >= 2000;

DEPART               AVG(SALARY)
-------------------- -----------
홍보부                    500100
-------------------------------------------------------


declare
	mdepart varchar(20);
	msalary number;
begin
	select depart, avg(salary)
	into mdepart, msalary 
	from members
	group by depart
	having avg(salary) >= 2000;
    
	dbms_output.put_line('부서: ' || msalary );
	dbms_output.put_line('평균: ' || msalary );
end;
/

부서: 500100
평균: 500100

PL/SQL 처리가 정상적으로 완료되었습니다.

좀더 편리함을 높일 수 있는 예제

[6주차] 33. PL/SQL언어, 변수의 타입을 간편하게 지정하는 방법, 1줄의 레코드를 한 번에 다 담을 수 있는 타입

Comments