피엘에스큐엘(PL/SQL)은 오라클(Oracle) 데이터베이스에서 에스큐엘(SQL) 언어를 확장하기 위해 사용하는 프로그래밍 언어이다. SQL 명령문으로는 처리하기 어려운 복잡한 자료의 저장이나 프로시저(Procedure)와 트리거(Trigger) 등을 작성할 때 사용한다.
개요
PL/SQL (Oracle's Procedural Language extension to SQL) 은 SQL의 확장된 개념으로 ORACLE에서 지원하는 프로그래밍 언어의 특성을 수용한 SQL의 확장이며, PL/SQL Block내에서 SQL의 DML(데이터 조작어)문과 Query(검색어)문, 절차형 언어(if,loop)등을 사용하여 다양한 저장 모듈을 개발할수있고 절차적 프로그래밍을 가능하게 한 강력한 트랜잭션 언어이다.[1]
특징
역사
1988년 7월에 소개된 오라클(Oracle) 버전6은 대용량 OLTP환경의 요구사항에 맞도록 개발되었다.이때 강조된 사항은 OLTP에 중대한 영향을 미치는 I/O,버퍼 관리, 동시성 제어, 백업 및 복구 등으로서 I/O시간을 줄여주기 위해 빠른 커밋(Fast Commit), 지연쓰기(Deffered Write)등이 소개되었으며, 시스템 가용성의 개선을 위해 온라인 백업 및 복구기능이 발표되었다.오라클 병렬 서버를 버전 6.2에 공식적으로 발표하였고, 버전6의 사용자들은 최초로 SQL문을 절차언어인 PL/SQL문과 함께 사용할 수 있게 되었다.[2]
장점
- PL/SQL은 블록(block) 구조로 되어 있어 각 기능별로 모듈화가 가능하다.
- 테이블의 데이터 구조와 데이터베이스(DataBase)의 컬럼에 준하여 동적으로 변수를 선언할 수 있다.
- IF, LOOP 등의 절차형 언어를 사용하여 절차적인 프로그램이 가능하다.
- Exception 처리 루틴을 이용하여 Oracle Server Error를 처리할 수 있다.
- PL/SQL은 Block 구조로 다수의 SQL문을 한번에 Oracle DB로 보내서 처리하므로 통신량을 감소시켜 수행 속도를 향상시킬 수 있다.
- PL/SQL은 오라클에 내장되어 있으므로 오라클과 PL/SQL을 지원하는 어떤 서버로도 프로그램을 옮길 수 있다.[1]
단점
- 기본 SQL로도 얼마든지 처리 가능함에도 불구하고 PL/SQL로 처리하는 경우 SQL 엔진과 PL/SQl 엔진 사이를 전환하면서 처리하는 컨텍스트 스위칭(context switching)이 발생하며 이것이 반복될 경우 성능이 떨어진다.
- 오라클(Oracle)은 쿼리의 수행 시작 시점을 기준으로 데이터를 보여주는데 SQL에서 PL/SQL을 사용하고 해당 PL/SQL내에서 또 다른 테이블을 조회 하는 경우 '쿼리의 수행이 시작된 시점'이 SQL과 PL/SQL간에 서로 다르게 적용되어 장시간 수행되면서 테이블에 변경이 일어날 경우 데이터 일관성이 깨지는 문제가 발생할 수 있다.
- PL/SQL 내에서 DB LINK 사용시 서비스 품질이 떨어지거나 네트워크 지연이 상당한 경우가 많다.
- 무분별하게 트리거(Trigger)를 사용할 경우 트리거(Trigger)에 의해 변경되는 데이터를 추적하기가 쉽지 않아 유지·보수가 힘들다. 또한 DBA가 테이블에 대해 작업을 할 경우에도 문제를 일으켜 장애의 원인이 되기도 한다.
활용
주로 자료 내부에서 SQL 명령문만으로 처리하기에는 복잡한 자료의 저장이나 프로시저와 트리거 등을 작성하는데 쓰인다. PL/SQL의 구조는 에이다 프로그래밍 언어를 본떠 만들어졌다고 알려졌다. 따라서 두 언어는 그 구조가 범용 언어인 파스칼의 구문과 비슷하다. 범용 언어인 C와 C++ 그리고 파스칼 및 포트란 등의 프로그래밍 언어와는 다른 점으로 범용 언어들이 컴퓨터 시스템에서 특정한 작업을 처리 하기 위해 만들어진 언어라고 볼 때 PL/SQL은 단지 오라클(Oracle)의 관계형 데이터베이스(RDBMS)에서만 사용된다.
종류
- 익명블럭 (anonymous PL/SQL block) : 이름이 없는 PL/SQL Block으로 DB에 저장되지 않고, 사용자가 실행하려는 SQL문을 필요로 할때마다 반복적으로 작성하여 실행하는 방법이다.
- 프로시저 (Procedure) : 리턴 값을 하나 이상 가질 수 있는 프로그램을 말한다.
- 함수 (Function) : 리턴 값을 반드시 반환해야 하는 프로그램을 말한다. 일반적으로 값을 계산하기 위해 사용된다.
- 트리거 (Trigger) : 지정된 이벤트가 발생하면 자동으로 실행되는 PL/SQL 블록이다.
- 패키지 (Package) : 하나 이상의 프로시저, 함수, 변수, 예외 등의 묶음을 말한다.[3]
각주
- ↑ 1.0 1.1 "PL/SQL이란?", 《네이버 블로그》
- ↑ by김정식, 〈지금의 오라클이라는 데이터베이스가 나오기 까지의 과정.〉, 《개인블로그》 , 2002-04-23
- ↑ Liam Han, 〈PL/SQL 개관 -1 (정의,특징,장점,Block의 종류)〉, 《네이버 블로그》 , 2016-07-07
참고자료
- Dr금, 〈PL/SQL이란?〉, 《네이버 블로그》 , 2010-02-23
- 김정식, 〈지금의 오라클이라는 데이터베이스가 나오기 까지의 과정.〉, 《개인 블로그》 , 2002-04-23
- Liam Han, 〈PL/SQL 개관 -1 (정의,특징,장점,Block의 종류)〉, 《네이버 블로그》 , 2016-07-07
같이 보기
이 피엘에스큐엘 문서는 프로그래밍에 관한 글로서 검토가 필요합니다. 위키 문서는 누구든지 자유롭게 편집할 수 있습니다. [편집]을 눌러 문서 내용을 검토·수정해 주세요.
|
개발 : 프로그래밍 □■⊕, 소프트웨어, 데이터, 솔루션, 보안, 하드웨어, 컴퓨터, 사무자동화, 인터넷, 모바일, 사물인터넷, 게임, 메타버스, 디자인
|
|
프로그래밍 언어
|
ASP • C 언어 • C++ • C# • CSS • D 언어 • HTML • HTML5 • JSP • PHP • R • XHTML • XML • XSLT • 고(Go) • 고급언어 • 기계어 • 델파이 • 러스트 • 루비 • 루아 • 리액트 • 리퀴디티 • 무브 • 미켈슨 • 베이직 • 브이비스크립트 • 비주얼 C++ • 비주얼베이직(VB) • 비주얼베이직닷넷(VB.NET) • 솔리디티 • 스몰토크 • 스위프트 언어 • 스칼라 • 스크립트 언어 • 알골 • 어셈블리 • 언리얼스크립트 • 얼랭 • 에이잭스(Ajax) • 엠에프씨(MFC) • 오브젝티브-C • 오브젝트 파스칼 • 오카멜 • 웹어셈블리(WASM) • 이와즘(eWASM) • 자바 • 자바스크립트 • 저급언어 • 제이슨(JSON) • 제이쿼리(jQuery) • 카멜 • 코볼 • 코틀린 • 콜드퓨전 • 타입스크립트 • 파스칼 • 파워스크립트 • 파이썬 • 펄(Perl) • 포트란 • 프로씨(Pro-C) • 피엘에스큐엘(PL/SQL) • 피엘원(PL/I) • 하스켈
|
|
개발방법론
|
CBD 개발방법론 • EA • 구조적 개발방법론 • 객체지향 개발방법론 • 라이브러리 • 람다 아키텍처 • 모듈 • 모듈화 • 벤치마킹 • 소프트웨어 개발방법론 • 스크럼 • 스프린트 • 아키텍처 • 아키텍트 • 애자일 • 웹개발방법론 • 정보공학 개발방법론 • 컴포넌트 • 테일러링 • 템플릿 • 폭포수 모델 • 프로젝트 • 프로토타입 • 피드백
|
|
코딩
|
EUC-KR • UTF-8 • 값 • 글루웨어 • 노팔로우 링크 • 두팔로우 링크 • 디버깅 • 디코딩 • 마크업 • 버그 • 부트스트랩 • 세이브포인트 • 소스코드 • 시큐어코딩 • 아스키 • 액티브엑스 • 오픈소스 • 유니코드 • 인코딩 • 재컴파일 • 주석 • 컴파일 • 컴퓨터 프로그램 • 코드 • 코딩 • 태그 • 테스트 • 테이블 • 텍스트 • 파싱 • 퍼블리싱 • 퓨니코드 • 하드코딩 • 하이퍼링크 • 하이퍼텍스트
|
|
프로그래밍
|
C 명령어 • 객체 • 객체지향 • 객체지향 프로그래밍 • 거짓 • 관계연산자 • 기본형 변수 • 널 • 논리 • 논리연산 • 논리연산자 • 다중상속 • 다형성 • 대입 • 대입문 • 대입연산자 • 더블 • 도스 명령어 • 디폴트 • 레지스터변수 • 루프 • 리눅스 명령어 • 리턴 • 메모리 주소 • 메소드 • 멤버 • 명령문 • 명령어 • 무한루프 • 문자 • 문자열 • 바이트 • 반복문 • 배열 • 변수 • 분기 • 분기문 • 불린 • 브레이크 • 비교연산자 • 비트연산자 • 산술연산자 • 상속 • 상수 • 생성자 • 선언 • 선언문 • 설정자 • 속성 • 스위치 • 스태틱 • 시프트연산자 • 실행 • 실행문 • 어노테이션 • 에코 • 역참조 • 연산 • 연산문 • 연산자 • 오버로딩 • 오버라이딩 • 외부변수 • 윈도우 명령어 • 유닉스 명령어 • 인스턴스 • 인스트럭션 • 인클루드 • 인터페이스 • 임포트 • 입력 • 입력문 • 입출력 • 입출력문 • 자료형(데이터 타입) • 자바 명령어 • 자바 예약어 • 자바 컬렉션 • 전역변수 • 접근자 • 접근제어자 • 정보은닉 • 정수형 • 정적변수 • 제어 • 제어문 • 제어자 • 조건 • 조건문 • 조건연산자 • 주소 • 증감연산자 • 지역변수 • 참 • 참조 • 참조변수 • 초기화 • 추상메소드 • 추상클래스 • 추상화 • 출력 • 출력문 • 캡슐화 • 케이스 • 클래스 • 파라미터(매개변수) • 파이널 • 패키지 • 퍼블릭 • 포인터 • 프라이빗 • 프로텍티드 • 필드(멤버변수) • 함수 • 환경변수
|
|
명령어
|
abstract • array • boolean • break • byte • case • char • continue • default • double • do while • echo • elif • else • else if • false • final • float • for • gosub • goto • if • if else • import • include • int • join • long • long long • null • print • printf • println • private • protected • public • return • scanf • short • stdio.h • static • string • switch • temp • then • true • unsigned • void • while
|
|
디자인패턴
|
구조패턴 • 동시성패턴 • 동시실행패턴 • 모델-뷰-컨트롤러 패턴 • 상태패턴 • 생성패턴 • 싱글톤패턴 • 아키텍처패턴 • 전략패턴 • 커맨드패턴 • 행동패턴
|
|
프로그래밍 인물
|
귀도 반 로썸 • 그레이스 머레이 호퍼 • 니클라우스 비르트 • 댄 브릭클린 • 더그 커팅 • 데니스 리치 • 리누스 토르발스 • 리처드 그린블라트 • 마거릿 해밀턴 • 마크 앤드리슨 • 빈트 서프 • 빌 게이츠 • 빌 조이 • 스티브 잡스 • 에이다 러브레이스 • 제임스 고슬링 • 척 벤턴 • 켄 톰슨 • 팀 패터슨
|
|
위키 : 자동차, 교통, 지역, 지도, 산업, 기업, 단체, 업무, 생활, 쇼핑, 블록체인, 암호화폐, 인공지능, 개발, 인물, 행사, 일반
|
|