Oracle存儲(chǔ)過程寫法實(shí)例

上城網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),上城網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為上城1000+提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站制作要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的上城做網(wǎng)站的公司定做!
總結(jié)項(xiàng)目中寫的存儲(chǔ)過程例子:
Oracle存儲(chǔ)過程基本語(yǔ)法 存儲(chǔ)過程
1 CREATE OR REPLACE PROCEDURE 存儲(chǔ)過程名
2 IS/AS
3 BEGIN
4 NULL;
5 EXCEIPTION;
6 END;
1、創(chuàng)建存儲(chǔ)過程,后面可用is或者as:
create or replace procedure PRO_COMPLAIN_TEMPLATE as
2、定義變量,此處用到了%TYPE和%ROWTYPE,參考 /database/201211/168564.html ,另外定義了一個(gè)游標(biāo),TEM_INSTANCE TEMPLATE_CUR%ROWTYPE這個(gè)類型定義必須要在游標(biāo)定義之后:
NEED_DO_FOR_ZL INTEGER;
CURRENT_MAX_ID MEMO_TEMPLET.TEMPLET_ID%TYPE;
CURSOR TEMPLATE_CUR IS SELECT TEMPLET_NAME, TEMPLET_CONTENT FROM SYS_COMPLAINT_TEMPLET;
TEM_INSTANCE TEMPLATE_CUR%ROWTYPE;
3、begin開始?jí)K:
begin
4、該插入語(yǔ)句使用了DBLINK,還有使用DBMS_OUTPUT.put_line('打印信息')進(jìn)行信息輸出:
insert into MEMO_TEMPLET (TEMPLET_ID, TEMPLET_CONTENT, TEMPLET_TYPE, TEMPLET_MEMO) (SELECT * FROM MEMO_TEMPLET@COMPANY);
SELECT COUNT(*) INTO NEED_DO_FOR_ZL FROM SYS_COMPLAINT_TEMPLET;
IF(NEED_DO_FOR_ZL 0) THEN
DBMS_OUTPUT.put_line('打印信息');
SELECT MAX(TEMPLET_ID)+1 INTO CURRENT_MAX_ID FROM MEMO_TEMPLET;
DBMS_OUTPUT.put_line('MEMO_TEMPLET最大ID' || CURRENT_MAX_ID);
FOR TEM_INSTANCE IN TEMPLATE_CUR LOOP
INSERT INTO MEMO_TEMPLET (TEMPLET_ID, TEMPLET_CONTENT,
TEMPLET_TYPE, TEMPLET_MEMO) VALUES (CURRENT_MAX_ID,
TEM_INSTANCE.TEMPLET_CONTENT, '7', NULL);
CURRENT_MAX_ID := CURRENT_MAX_ID + 1;
DBMS_OUTPUT.put_line(TEM_INSTANCE.TEMPLET_CONTENT);
END LOOP;
END IF;
COMMIT;
4、exception塊,使用WHEN OTHERS THEN,其中用raise可顯示錯(cuò)誤信息:
exception
WHEN OTHERS THEN
DBMS_OUTPUT.put_line('sqlcode : ' ||sqlcode);
raise;
ROLLBACK;
IF TEMPLATE_CUR%ISOPEN THEN
CLOSE TEMPLATE_CUR;
END IF;
DBMS_OUTPUT.put_line('打印信息');
end;
注:關(guān)于游標(biāo)的使用,如果像本例中使用for循環(huán)去遍歷游標(biāo)的話則不需要顯式的去用open/close
cursor打開和關(guān)閉游標(biāo),此處會(huì)自己處理,如果使用fetch
into的話就需要顯式開關(guān)游標(biāo),另外任意執(zhí)行一個(gè)update操作,用隱式游標(biāo)sql的屬性%found,%notfound,%rowcount,%isopen觀察update語(yǔ)句的執(zhí)行情況,也可以使用來判斷游標(biāo)狀態(tài),如IF
TEMPLATE_CUR%ISOPEN THEN。
create or replace procedures_name(參數(shù)名1 in 參數(shù)類型1,參數(shù)名 in 參數(shù)類型2....) is
變量名1 變量類型1 :=賦值;
變量名2 變量類型2 :=賦值;
定義游標(biāo):cursor(固定寫法) cursor_name(自定義) is select * from table_name;
begin
這中間寫sql,至于if和循環(huán)什么的自己上網(wǎng)看一些Oracle存儲(chǔ)過程的語(yǔ)法
end procedures_name;
create or replace procedure Pr_UserLogin (
username varchar,
password varchar
)
as
begin
--過程體
end
另外,oracle的存儲(chǔ)過程不能像sqlserver那樣直接反正一個(gè)結(jié)果集。需要用程序包來實(shí)現(xiàn)。
包用于在邏輯上組合過程和函數(shù),它由包規(guī)范和包體兩部分組成
1.創(chuàng)建包
--創(chuàng)建一個(gè)包sp_package
create?package?sp_package?is
--聲明該包有一個(gè)過程和函數(shù),(沒有實(shí)現(xiàn))
procedure?update_sal(name?varchar2,newsal?number);
function?annual_nicome(name?varchar2)?return?number;
end;
--創(chuàng)建包體(用于實(shí)現(xiàn)已經(jīng)聲明的函數(shù)和過程)
create?package?body?sp_package?is
procedure?update_sal(name?varchar2,newsal?number)
is
BEGIN
UPDATE?emp
SET????sal?=?newsal
WHERE??ename?=?name;
END;
function?annual_income(name?varchar2)
return?number?is
annual_salary?number;
BEGIN
SELECT?sal?*?12?+?Nvl(comm,0)
INTO???annual_salary
FROM???emp
WHERE??ename?=?name;
RETURN?annual_salary;
END;
end;
--調(diào)用包中的內(nèi)容
exec?sp_package.update_sal('name',number);
---創(chuàng)建
create or replace procedure GenTestUserData(nRecordCount in number Default 50000) is
nCurrentCount number; -- 當(dāng)前表中記錄
nMaxLogID number;
nInsertCount number;
begin
select Count(LogID), Nvl(Max(LogID), 0)
into nCurrentCount, nMaxLogID
from MyUser;
nInsertCount:= nRecordCount - nCurrentCount;
if nInsertCount = 0 then
Return;
end if;
-- 插入數(shù)據(jù)
insert into MyUser(FirstName, LastName, LogID, Mail, Location)
select FirstName, LastName, LogID, 'MyUser@' || To_Char(LogID) || '.Com', '.' || To_Char(LogID) || '.Com'
from (select GetRandomHZ FirstName, GetRandomHZ LastName, nMaxLogID + Rownum LogID
from All_Tab_Columns
where Rownum = nInsertCount) TestData;
end;
/
--刪掉
drop procedure GenTestUserData;
Oracle存儲(chǔ)過程基本語(yǔ)法:
CREATE?OR?REPLACE?PROCEDURE?存儲(chǔ)過程名?
IS?
BEGIN?
NULL;?
END;
解釋:
行1:?
CREATE OR REPLACE PROCEDURE 是一個(gè)SQL語(yǔ)句通知Oracle數(shù)據(jù)庫(kù)去創(chuàng)建一個(gè)叫做skeleton存儲(chǔ)過程, 如果存在就覆蓋它;?
行2:?
IS關(guān)鍵詞表明后面將跟隨一個(gè)PL/SQL體。?
行3:?
BEGIN關(guān)鍵詞表明PL/SQL體的開始。?
行4:?
NULL PL/SQL語(yǔ)句表明什么事都不做,這句不能刪去,因?yàn)镻L/SQL體中至少需要有一句;?
行5:?
END關(guān)鍵詞表明PL/SQL體的結(jié)束。
本文名稱:oracle過程包怎么寫,oracle 過程包授權(quán)
本文鏈接:http://chinadenli.net/article9/dsigdoh.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、面包屑導(dǎo)航、關(guān)鍵詞優(yōu)化、、外貿(mào)建站、響應(yīng)式網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)