Notice
Recent Posts
Recent Comments
관리 메뉴

Developer Gonie

[6주차] 37. PL/SQL언어, 예외처리 및 예외 강제로 발생시키기, 사용자 정의 예외 본문

K-DigitalTraining 강의/2. Oracle + PLSQL

[6주차] 37. PL/SQL언어, 예외처리 및 예외 강제로 발생시키기, 사용자 정의 예외

이대곤 2022. 6. 20. 11:07

예외의 종류

- others : Java에서의 Exception 클래스와 같이 모든 예외를 받을 수 있음.

- too_many_rows : 2줄 이상의 레코드가 조회되었을 때 발생하는 예외
- no_data_found : 발견된 레코드가 없을 때 발생하는 예외

이외에도 구글에 plsql 예외처리 라고 입력하면 더 다양한 예외를 볼 수 있다.

1개의 예외만을 다루는 예시

declare
	i number;
begin
	i := 6/0;
	dbms_output.put_line('i:' || i);
end;
/

1행에 오류:
ORA-01476: 제수가 0 입니다
-----------------------------------------------------------------
declare
	i number;
begin
	i := 6/0;
	dbms_output.put_line('i:' || i);

-- others : Java에서의 Exception 클래스와 같이 모든 예외를 받을 수 있음.
exception
	when others then
		dbms_output.put_line('예외발생: 0으로 나누려는 시도');
end;
/

예외발생: 0으로 나누려는 시도

PL/SQL 처리가 정상적으로 완료되었습니다.
declare
	vno book.no%type;
	vtitle book.title%type;
begin
	select no, title
	into vno, vtitle
	from book;

	dbms_output.put_line(vno || ',' || vtitle);
end;
/

1행에 오류:
ORA-01422: 실제 인출은 요구된 것보다 많은 수의 행을 추출합니다
-----------------------------------------------------------------
declare
	vno book.no%type;
	vtitle book.title%type;
begin
	select no, title
	into vno, vtitle
	from book;

	dbms_output.put_line(vno || ',' || vtitle);
--too_many_rows : 여러줄을 가져오려고 하면 발생하는 예외
exception
	when too_many_rows then
		dbms_output.put_line('예외발생: 두 줄 이상의 레코드를 가져오려는 시도입니다.');
end;
/

예외발생: 두 줄 이상의 레코드를 가져오려는 시도입니다.

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

2개 이상의 예외를 다루는 예시


declare
	vno book.no%type;
	vtitle book.title%type;
begin
	select no, title
	into vno, vtitle
	from book
	where title like '%가%';

	dbms_output.put_line(vno || ',' || vtitle);
--too_many_rows : 2줄 이상의 레코드가 조회되었을 때 발생하는 예외
--no_data_found : 발견된 레코드가 없을 때 발생하는 예외
exception
	when no_data_found then
		dbms_output.put_line('예외발생: 조건에 맞는 레코드가 없습니다.');
	when too_many_rows then
		dbms_output.put_line('예외발생: 두 줄 이상의 레코드를 가져오려는 시도입니다.');
end;
/

예외발생: 조건에 맞는 레코드가 없습니다.

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

원하지 않는 값 입력시 강제로 예외 발생시키는 예제

아래의 예제는 필드의 값으로 음수를 이용해 insert 하려고 하면 예외를 강제로 발생시키는 예제이다.
invalid_number 예외는 문자를 숫자를 변경할때 이를 변경시킬 수 없을 때 발생하는 것인데

여기서는 그냥 음수를 받을 때 예외처리를 위해 임의로 아무 예외나 발생시킨 것임. 

예외를 강제로 발생시키고 싶다면 "raise 예외명" 을 해주면 된다. 

create or replace procedure employee_proc(veno employee.eno%type, 
					vename employee.ename%type, 
					vdeptno employee.deptno%type)
is

begin
	if veno < 0 then
		raise invalid_number; -- 강제로 예외 발생시키기	
	end if;

	insert into employee values(veno, vename, vename );
exception
	when invalid_number then
		dbms_output.put_line('사원번호는 양수만 가능합니다.');
end;
/

사용자 정의 예외

EXCEPTION 타입으로 예외를 내가 만들어줘야 다른 예외처럼 똑같이 사용이 가능하다.

create or replace procedure employee_proc(veno employee.eno%type, 
					vename employee.ename%type, 
					vdeptno employee.deptno%type)
is
	makeError EXCEPTION; -- 사용자 정의 예외 변수 선언
begin
	if veno < 0 then
		raise makeError; -- 강제로 예외 발생시키기	
	end if;

	insert into employee values(veno, vename, vename );
exception
	when makeError then
		dbms_output.put_line('사원번호는 양수만 가능합니다.');
end;
/
Comments