저장 프로시저는 SQL 서버에서 실행되는 SQL문을 모아놓은 함수라고 할 수 있다.
저장 프로시저를 이용하는 이유는 SQL 문을 서버에서 직접 실행하고 컴파일 하므로 좀 더 빠른 속도를 낼 수 있기 때문이다.
저장 프로시저 만드는 방법은 다음과 같다.
먼저 SQL Server 2008 Management Studio를 실행을 하고 프로시저를 실행하고자 하는 데이타베이스를 선택을 하고, 프로그래밍 기능을 클릭하면 저장 프로시저가 보인다. 여기사 저장 프로시저를 선택을 하고 마우스 오른쪽 버튼을 누르면 새 저장 프로시저가 있다. 그리고 나서 다음과 같이 작성 후 저장을 하면 해당 데이타베이스에 저장이 된다.
CREATE PROCEDURE 프로시저 이름
인자1,
인자2
...
AS
BEGIN
실행하는 SQL 문
...
END
여기서 PROCEDURE 대신 PROC라고 해도 된다.
저장 프로시저 만드는 예는 다음과 같다.
먼저 매개변수가 없는 예이다.
CREATE PROCEDURE usp_GetList
AS
SELECT * FROM 테이블명; --> 실행문이 1줄인 경우 BEGIN문과 END문을 생략할 수 있다.
이를 SQL 서버에서 실행할 때는 EXECUTE나 EXEC usp_GetList 라고 입력하면 된다.
만약 스크립트 문의 첫번째 행이 저장 프로시저 문을 실행하는 구문이라고 하면 EXECUTE나 EXEC를 생략할 수 있다.
즉 usp_GetList라고 입력하면 된다.
입력 매개변수 있는 저장 프로시저 예이다.
입력 매개변수는 변수명 앞에 @을 추가한다. 그리고 변수명 다음에 데이터 형을 입력한다.
CREATE PRPCEDURE usp_Input
@sbno char(10),
@sbname char(20),
@sbemail char(50)
AS
INSERT INTO 테이블명 (sbno, sbname, sbemail) VALUES (@sbno, @sbname, @sbemail);
실행하는 예이다.
EXEC usp_Input '1234', '홍길도', 'hong@naver.com';
출력 매개변수 있는 저장 프로시저 예이다.
출력 매개변수는 변수명 앞에 @을 추가하고, 변수명 다음에 데이터 형과 OUTPUT 이라는 명령어를 명시해야 한다.
CREATE PROC usp_Output
@umax smallint OUTPUT
AS
SELECT @umax = max(최대값을구하는열) FROM 테이블;
실행하는 예이다.
DECLARE @maxvalue smallint;
EXEC usp_Output @umax = @maxvalue OUTPUT;
SELECT * FROM 테이블명 WHERE 구하고자하는 열 = @maxvalue;