db2 存儲過程

 
如何聲明一個存儲過程
CREATE PROCEDURE 存儲過程名(IN 輸入變量名 輸入變量類型,OUT 輸出變量名 輸出變量類型)
緊跟其後的是存儲過程屬性列表
            常用的有:LANGUAGE SQLMODIFIES SQL DATA、RESULT SETS 1(返回結果集個數)
l         存儲過程體以begin開始
l         存儲過程體以end結束
存儲過程約束規則
存儲過程中調用存儲過程
CALL 存儲過程名(參數1,參數2,參數n)
例:
call spco_init_custom(bankcode,errno,errmsg);
GET DIAGNOSTICS retval=RETURN_STATUS;
if(retval<>0) then
    set errno=errno;
    set errmsg=errmsg;
    return errno;
end if;
            
變量的定義
變量使用前必須先定義,方法爲
DECLARE 變量名 變量類型 (default 默認值)
例:
DECLARE SQLCODE INTEGER DEFAULT 0;
DECLARE inum INTEGER DEFAULT 0;
DECLARE curtime char(8);
DECLARE bcode char(6);
DECLARE sqlstate char(5);
if 表達式
if 條件1 then
邏輯體;
elseif 條件2 then
邏輯體;
else
邏輯體;
end if;
例:
IF rating = 1 THEN
UPDATE employee
SET salary = salary * 1.10, bonus = 1000
WHERE empno = employee_number;
ELSEIF rating = 2 THEN
UPDATE employee
SET salary = salary * 1.05, bonus = 500
WHERE empno = employee_number;
ELSE
UPDATE employee
SET salary = salary * 1.03, bonus = 0
WHERE empno = employee_number;
END IF;
case表達式
case 變量名 when
       變量值1 then
       . . .
when
       變量值2 then
- - -
else
. . .
end case;
case when
       變量名=變量值1 then
       . . .
when
       變量名=變量值2 then
- - -
else
. . .
end case;
例一:
CASE v_workdept
WHEN 'A00'
THEN UPDATE department
SET deptname = 'DATA ACCESS 1';
WHEN 'B01'
THEN UPDATE department
SET deptname = 'DATA ACCESS 2';
ELSE UPDATE department
SET deptname = 'DATA ACCESS 3';
END CASE
例二:
CASE
WHEN v_workdept = 'A00'
THEN UPDATE department
SET deptname = 'DATA ACCESS 1';
WHEN v_workdept = 'B01'
THEN UPDATE department
SET deptname = 'DATA ACCESS 2';
ELSE UPDATE department
SET deptname = 'DATA ACCESS 3';
END CASE
for 表達式
for 循環名 as
   遊標名或select 表達式
do
    sql表達式;
end for;
例:
1
DECLARE fullname CHAR(40);
FOR vl AS
SELECT firstnme, midinit, lastname FROM employee
DO
SET fullname = lastname || ',' || firstnme ||' ' || midinit;
INSERT INTO tnames VALUE (fullname);
END FOR
2
for loopcs1 as   cousor1   cursor   as
select   market_code   as market_code
            from tb_market_code
            for update
         do
end for;
goto表達式
goto 標示名;
標示名:
   邏輯體;
例:
   GOTO FAIL
...
SUCCESS: RETURN 0
FAIL: RETURN -200
while表達式
while 條件表達式 do
       邏輯體;
end while;
LOOP表達式
LOOP... END LOOP
例:
OPEN c1;
ins_loop:
LOOP
FETCH c1 INTO v_dept, v_deptname, v_admdept;
IF at_end = 1 THEN
LEAVEins_loop; --中斷循環
ELSEIF v_dept = 'D11' THEN
ITERATEins_loop; --下一個循環
END IF;
INSERT INTO department (deptno, deptname, admrdept)
VALUES ('NEW', v_deptname, v_admdept);
END LOOP;
CLOSE c1;
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章