1. 변수와 상수
- 변수
변수는 다른 프로그래밍 언어에서 사용하는 개념과 같으며, 선언부에서 선언하고 실행부에서 사용한다.
변수명 데이터타입 := 초깃값;
-- 초깃갓을 할당하지 않으면 데이터 타입에 상관없이 초깃값이 null
-- 선언부에서는 선언만 하고 실행부에서 초깃값 할당하는 것도 가능
- 상수
상수 선언도 변수 선언과 비슷하다. 단, 상수는 변수와는 달리 한 번 값을 할당하면 변하지 않는다.
상수명 CONSTANT 데이터타입 := 상수값;
-- 상수는 특정 값을 할당해 놓고 실행부에서 사용하고자 할 때 사용
2. 연산자
PL/SQL 블록에서는 모든 SQL 연산자를 사용할 수 있으며, 추가적으로 제곱연산자('**')가 있다. 제곱연산자는 우선순위가 가장 높다.
- SQL 연산자 참고
DECLARE
A INTEGER := 2**2*3**2;
BEGIN
DBMS_OUTPUT.PUT_LINE('A = ' || A);
END;
/
3. DML문
PL/SQL 블록은 테이블 상에 있는 데이터를 가공해서 특정 로직에 따라 무언가를 처리하는 게 주 목적이기에, 주로 사용되는 것은 SQL문이다. 그 중 DML문만 사용한다.
DECLARE
-- V_NAME VARCHAR2(100);
V_NAME STUDENT.NAME%TYPE; -- 해당 변수의 컬럼 타입을 자동으로 가져온다.
-- V_DEPTNO NUMBER;
V_DEPTNO STUDENT.DEPTNO%TYPE;
BEGIN
SELECT NAME, DEPTNO
INTO V_NAME, V_DEPTNO -- INTO를 이용해 변수에 값을 할당
FROM STUDENT
WHERE STUDNO = 10101;
DBMS_OUTPUT.PUT_LINE(V_NAME || '-' || V_DEPTNO);
END;
/
4. 주석
PL/SQL은 SQL 구문의 주석과 동일하다.
-- 한 줄 주석
/* 범위 주석 */
참고문헌 : 홍형경(2015), 오라클 SQL과 PL/SQL을 다루는 기술, 길벗