일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 콜렉션
- 스프링
- 제네릭
- Java
- Short
- 빌드
- 박싱
- boxing
- 내장객체
- 인텔리제이
- 루프
- 무한
- suvlet
- 메소드
- maven
- 클래스
- unboxing
- Jenkins
- https://start.spring.io
- 언박싱
- bootstrap
- wrapper
- 제너릭
- dependency
- start.spring.io
- 자동형변환
- 컬렉션
- 싱글턴
- Scanner
- 싱글톤
Archives
- Today
- Total
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;
/
'K-DigitalTraining 강의 > 2. Oracle + PLSQL' 카테고리의 다른 글
[6주차] 38. 마지막 핵심 종합 Test(지금까지 공부한 것을 점검) (0) | 2022.06.22 |
---|---|
[6주차] 36. PL/SQL언어, 한 줄 씩 가져와 모든 행의 레코드를 출력하는 방법(커서, 커서 + for~loop) (0) | 2022.06.20 |
[6주차] 35. PL/SQL언어, 사용자 정의 프로시저(함수와 비슷하지만 반환값이 없음) (0) | 2022.06.17 |
[6주차] 34. PL/SQL언어, 재사용 가능한 이름있는 함수 작성방법 (0) | 2022.06.17 |
[6주차] 33. PL/SQL언어, 반복문의 종류(loop, for ~loop, while, 이중 반복문) (0) | 2022.06.17 |
Comments