PART I PL/SQL 시작하기 1
CHAPTER 1 예제로 시작하기 3
1.1 오라클 scott 예제 스키마 3
1.2 예제 프로그램 6
1.2.1 익명 PL/SQL 예제 6
1.2.2 저장 함수 예제 12
1.2.3 저장 프로시저 예제 15
CHAPTER 2 PL/SQL 개요 20
2.1 PL/SQL의 개념 21
2.2 PL/SQL의 주요 특징 22
2.3 PL/SQL과 SQL의 비교 25
2.4 PL/SQL로 쉽게 할 수 있는 것들과 하기 어려운 것들 27
2.4.1 쉽게 할 수 있는 것들 27
2.4.2 하기 어려운 것들 28
2.5 PL/SQL의 작성과 실행 절차 28
2.6 PL/SQL의 실행 구조 29
CHAPTER 3 PL/SQL 프로그래밍 준비하기 31
3.1 오라클의 세 가지 에디션 31
3.2 오라클 데이터베이스 설치 32
3.2.1 사용할 오라클 버전의 선택 32
3.2.2 오라클 데이터베이스 설치 절차 32
3.2.3 오라클 버전 12c 사용 시의 주의사항 34
3.3 PL/SQL 실행 환경 36
3.4 SQL*Plus 설정 38
PART II PL/SQL의 기초 39
CHAPTER 4 PL/SQL 프로그램의 기본 구조 41
4.1 블록 구조 41
4.2 문장 44
4.3 주석 45
4.4 저장 서브프로그램과 익명 PL/SQL 46
CHAPTER 5 구분자와 식별자 48
5.1 구분자 48
5.2 식별자 50
5.2.1 일반 사용자 정의 식별자 53
5.2.2 큰따옴표를 사용한 사용자 정의 식별자 54
5.3 식별자의 유효 범위 55
CHAPTER 6 데이터 타입 59
6.1 문자형 데이터 타입 60
6.2 수치형 SQL 데이터 타입 63
6.3 LONG과 LONG RAW 데이터 타입 65
6.4 PL/SQL 전용 데이터 타입 65
6.4.1 PL/SQL 전용 수치형 데이터 타입 65
6.4.2 BOOLEAN 데이터 타입 66
6.5 사용자 정의 서브타입 69
6.6 객체 타입 70
6.7 오라클 내장 데이터 타입의 최대 크기 차이 70
6.8 앵커(%)를 사용한 데이터 타입 지정 71
6.8.1 %TYPE 71
6.8.2 %ROWTYPE 72
6.9 스칼라 데이터 타입과 컴포지트 데이터 타입 73
CHAPTER 7 변수와 상수 그리고 리터럴 75
7.1 변수 75
7.2 상수 78
7.3 리터럴 79
7.3.1 문자형 리터럴 81
7.3.2 수치형 리터럴 84
7.3.3 날짜형 리터럴 86
CHAPTER 8 표현식 89
8.1 연산자와 피연산자 89
8.2 연산자 우선순위 90
8.3 연산자의 기능 설명 91
8.4 연산자의 종류 91
8.4.1 산술 연산자 92
8.4.2 논리 연산자 92
8.4.3 Short-Circuit Evaluation 94
8.4.4 연결 연산자 95
8.4.5 비교 연산자 95
8.4.6 BOOLEAN 표현식 101
8.4.7 CASE 표현식 102
8.5 PL/SQL에서 내장 SQL 함수의 사용 105
CHAPTER 9 SQL 실행 107
9.1 SELECT문의 사용 107
9.1.1 기본 사용법 107
9.1.2 PL/SQL 입력 변수의 사용 108
9.2 INSERT문의 사용 111
9.3 UPDATE문의 사용 113
9.4 MERGE문의 사용 115
9.5 DELETE문의 사용 117
9.6 시퀀스 사용 117
9.7 DML문의 결괏값을 PL/SQL 변수로 반환하는 방법 118
9.8 트랜잭션 제어 120
9.8.1 COMMIT 121
9.8.2 묵시적 COMMIT 122
9.8.3 ROLLBACK 123
9.8.4 SAVEPOINT 124
9.8.5 묵시적 ROLLBACK 126
9.8.6 SET TRANSACTION 128
9.9 CLOB 사용하기 129
PART III 절차형 데이터베이스 언어로서의 PL/SQL 133
CHAPTER 10 제어문 135
10.1 제어문의 종류 135
10.2 조건 분기문 136
10.2.1 IF문 136
10.2.2 CASE문 138
10.3 무조건 분기문 144
10.4 레이블 146
10.5 순환문 149
10.5.1 기본 LOOP문 149
10.5.2 탈출문 150
10.5.3 WHILE LOOP문 151
10.5.4 FOR LOOP문 152
10.5.5 LOOP문 내에서의 흐름 변경 156
10.6 제어 구조의 중첩 157
CHAPTER 11 컬렉션 160
11.1 컬렉션 타입의 종류 161
11.2 Associative Array 163
11.3 VARRAY(Variable-Size Array) 167
11.4 Nested Table 170
11.5 컬렉션 생성자 174
11.6 컬렉션 연산 175
11.6.1 컬렉션 변수 간의 할당 175
11.6.2 컬렉션 비교 177
11.6.3 컬렉션 메소드 178
11.7 다차원 컬렉션 180
11.8 배열 처리 180
11.8.1 SELECT문에서의 배열 처리 181
11.8.2 DML문에서의 배열 처리 185
11.8.3 FORALL문과 예외 처리 188
CHAPTER 12 레코드 191
12.1 레코드 사용 191
12.2 레코드를 SQL에 사용하기 193
12.3 레코드 변수에 값 할당 197
12.4 레코드와 컬렉션의 혼합 199
12.5 레코드를 SELECT, INSERT, UPDATE문에 사용할 때의 제약 사항 200
CHAPTER 13 커서 201
13.1 묵시적 커서와 명시적 커서 202
13.1.1 묵시적 커서 203
13.1.2 명시적 커서 203
13.2 커서 FOR LOOP 208
13.2.1 묵시적 커서 FOR LOOP 209
13.2.2 명시적 커서 FOR LOOP 211
13.3 커서 속성 211
13.3.1 명시적 커서 속성 212
13.3.2 묵시적 커서 속성 214
13.4 커서 칼럼의 앨리어스 사용 215
13.5 커서 매개변수 216
13.6 커서 변수(REF CURSOR) 217
13.7 SELECT FOR UPDATE 222
CHAPTER 14 동적 SQL 225
14.1 EXECUTE IMMEDIATE문을 사용하는 방법 227
14.1.1 쿼리 결과를 변수에 저장 228
14.1.2 바인드 변수의 사용 228
14.1.3 바인드 변수의 모드 229
14.1.4 바인드 변수 플레이스 홀더의 이름과 순서 230
14.2 커서 변수를 사용하는 방법 232
14.3 DBMS_SQL 내장 패키지를 사용하는 방법 233
14.4 동적 PL/SQL 238
CHAPTER 15 예외 처리 240
15.1 예외 처리 방법 240
15.2 예외의 이름 243
15.2.1 표준 예외명 243
15.2.2 사용자 정의 예외명 250
15.3 사용자가 예외를 발생시키기 251
15.3.1 RAISE문 사용 251
15.3.2 RAISE_APPLICATION_ERROR 252
15.4 예외를 특정 오류 번호와 연결하기 255
15.5 예외의 전파 256
15.6 예외 처리기에서의 오류 조회 함수 257
15.6.1 FORMAT_ERROR_BACKTRACE 258
15.6.2 FORMAT_ERROR_STACK 258
15.6.3 FORMAT_CALL_STACK 259
15.7 예외 처리에서 주로 하는 작업 261
15.7.1 트랜잭션 마무리 261
15.7.2 변수나 반환값 지정 262
15.7.3 디버깅 정보 출력 263
15.7.4 오류 무시 265
PART IV 저장 서브프로그램 267
CHAPTER 16 저장 서브프로그램 개요 269
16.1 저장 서브프로그램을 사용하는 이유 269
16.2 저장 서브프로그램의 종류 270
16.3 프로그램을 서버에 저장하고 공유하기 271
16.4 저장 서브프로그램의 컴파일과 실행 방법 272
16.4.1 컴파일하기 273
16.4.2 컴파일 오류 조회 274
16.4.3 저장 서브프로그램 실행하기 276
16.5 서버에 저장되지 않는 서브프로그램 279
CHAPTER 17 저장 함수 282
17.1 함수의 기본 구조 282
17.2 함수의 매개변수 284
17.3 함수의 선언부 285
17.4 함수의 반환값 286
17.5 저장 함수의 사용 289
17.6 저장 함수 사용의 제약 사항 289
CHAPTER 18 저장 프로시저 291
18.1 프로시저의 매개변수 293
18.2 프로시저의 선언부 293
18.3 저장 프로시저의 사용 293
CHAPTER 19 패키지 294
19.1 패키지 구조 294
19.2 패키지 변수 298
19.3 패키지 서브프로그램 304
19.4 패키지 커서 306
19.5 SERIALLY_REUSABLE 패키지 308
CHAPTER 20 서브프로그램의 다양한 기능들 311
20.1 매개변수 311
20.1.1 매개변수의 선언과 사용 311
20.1.2 IN/OUT 매개변수 312
20.1.3 매개변수의 기본값 314
20.1.4 매개변수의 값 지정 방법: 위치에 의한 지정과 이름에 의한 지정 315
20.1.5 OUT 매개변수 변경의 원자성 보장 316
20.1.6 매개변수의 전달 방식: 값에 의한 호출과 참조에 의한 호출 318
20.1.7 NOCOPY 매개변수 319
20.2 재귀 호출 321
20.3 서브프로그램 정의의 중첩 321
20.4 중복 정의 323
20.4.1 중복 정의의 사용 323
20.4.2 중복 정의의 제약 327
20.5 전방 선언 328
20.6 자치 트랜잭션 329
20.7 함수 속성 DETERMINISTIC, PARALLEL_ENABLE, RESULT_CACHE 332
20.7.1 DETERMINISTIC 333
20.7.2 PARALLEL_ENABLE 333
20.7.3 RESULT_CACHE 334
20.8 권한 모델: 정의자 권한과 실행자 권한 334
20.8.1 정의자 권한 337
20.8.2 실행자 권한 338
20.8.3 ROLE을 통해 부여 받은 권한: SQL은 실행되는데 서브프로그램에 포함시키면 오류 발생 340
CHAPTER 21 트리거 344
21.1 트리거의 종류 345
21.2 DML 트리거의 구조 346
21.3 트리거의 호출 순서 349
21.4 트리거의 제약 사항 350
CHAPTER 22 객체 타입 352
22.1 객체 타입 개념 352
22.2 객체 타입 속성 355
22.3 객체 타입의 메소드 355
22.3.1 멤버 메소드 356
22.3.2 정적 메소드 362
22.3.3 생성자 메소드 363
22.4 객체 타입의 상속 369
22.5 메소드의 재정의 370
22.6 메소드의 중복 정의 373
22.7 REF 데이터 타입 374
22.8 객체를 테이블에 저장하는 방법 379
22.9 슈퍼타입과 서브타입 간의 변환 381
22.10 객체 타입의 진화 384
22.10.1 메소드의 추가 또는 삭제 385
22.10.2 속성의 추가, 삭제, 변경 386
22.10.3 타입의 FINAL과 NOT FINAL의 변경 387
CHAPTER 23 저장 서브프로그램 관리 388
23.1 변경과 삭제 388
23.2 딕셔너리에서 저장 서브프로그램 조회하기 389
23.3 저장 서브프로그램 권한 관리 391
CHAPTER 24 외부 프로그램에서 저장 서브프로그램 호출 394
24.1 자바 프로그램에서 저장 서브프로그램 호출 395
24.1.1 자바에서 저장 함수 호출 396
24.1.2 자바에서 저장 프로시저 호출 398
24.2 C# 프로그램에서 저장 서브프로그램 호출 401
24.2.1 C#에서 오라클을 사용하기 위한 준비 402
24.2.2 C#에서 저장 함수 호출 405
24.2.3 C#에서 저장 프로시저 호출 409
CHAPTER 25 자바 저장 프로시저 412
25.1 자바 저장 프로시저의 작성 방법과 절차 413
25.1.1 자바 클래스 파일을 DB에 로드 415
25.1.2 자바 소스 파일을 DB에 로드 417
25.1.3 자바 소스를 DB에 직접 생성 418
25.2 오라클의 SQL 데이터 타입과 자바 타입 간의 매핑 419
25.3 자바 저장 프로시저에서 자신을 실행한 오라클에 접속하기 421
25.4 오라클에서 지원하지 않는 기능을 자바로 구현하기 426