Oracle之存儲過程和存儲函數(shù)

1.存儲過程

將一段已經(jīng)編譯好的代碼,封裝到數(shù)據(jù)庫中

1. 作用 :

提高了代碼的復(fù)用性

因?yàn)橐约熬幾g好了,可以提高了執(zhí)行效率

關(guān)鍵字 - procedure /pr?’si?d??/ 過程,程序,手續(xù)

2. 語法:

create [or replace] procedure

? ? 過程名稱(參數(shù)1 in|out 參數(shù)類型,參數(shù)2 in|out 參數(shù)類型)

? is | as

? ? -- 聲明

? begin

? ? -- 業(yè)務(wù)

? end;


調(diào)用方法:

? ? 一: call 過程名稱(參數(shù));

? ? 二: plsql中使用:

? ? ? ? begin

? ? ? ? ? ? 過程名稱(參數(shù));

? ? ? ? end;? ?

1.輸入?yún)?shù)

定義一個存儲過程,給員工編號為7369的員工漲1000工資

代碼實(shí)現(xiàn):

create or replace procedure

? update_sal(vempno in number,vcount in number)

is

? -- 聲明變量記錄當(dāng)前工資

? cur_sal number;

begin

? -- 先查詢漲工資前的工資

? select sal into cur_sal from emp where empno = vempno;

? dbms_output.put_line('漲工資前: '||cur_sal);

? -- 更新工資

? update emp set sal = sal + vcount where empno = vempno;

? -- 漲工資后的工資

? dbms_output.put_line('漲工資后: '||(cur_sal+vcount));

? commit;

end;

調(diào)用:

call update_sal(7369,1000);

begin

? ? update_sal(7369,1000);

end;

2.輸出參數(shù)

根據(jù)員工編號,得到年薪

create or replace procedure

? year_sal(vempno in number,vyearsal out number)

as

begin

? select sal*12 + nvl(comm,0) into vyearsal --nvl(a,b) 如果a為null,則取b

? ? from emp where empno = vempno;

end;

調(diào)用:

declare

? yearsal number;

begin

? year_sal(7369,yearsal);

? dbms_output.put_line(yearsal);

end;?

3.輸出的是游標(biāo)類型:

游標(biāo)的類型是sys_refcursor

打開游標(biāo)并獲取數(shù)據(jù)一步合成:

open 游標(biāo)名 for 查詢語句

定義游標(biāo):

create or replace procedure

? findall_cursor(vcursor out sys_refcursor)

is


begin

? --打開游標(biāo),指定結(jié)果集

? open vcursor for select * from emp;

end;

emp%rowtype 指的是emp的行類型

%type可以使變量獲得與字段相同的數(shù)據(jù)類型

調(diào)用

declare

? yb sys_refcursor;

? -- 定義一個vrow變量膳叨,類型是emp的行類型

? vrow emp%rowtype;

begin

? findall_cursor(yb);

? loop

? ? ? fetch yb into vrow;

? ? ? exit when yb%notfound;

? ? ? dbms_output.put_line('編號:'||vrow.empno||' 姓名:'||vrow.ename);

? end loop;

? -- 關(guān)閉游標(biāo)

? close yb;

end;

2.存儲函數(shù)

實(shí)質(zhì)是跟存儲過程一樣

和存儲過程的區(qū)別:

函數(shù)有返回值,過程沒有,函數(shù)的返回值可以用:=接收

函數(shù)可以直接在sql中調(diào)用,過程不能

函數(shù)和過程都實(shí)現(xiàn)對方的功能.

語法:

create [or replace] function

? ? 函數(shù)名稱(參數(shù)1? 參數(shù)類型) return 返回類型

? is

? ? 返回變量 變量類型

? begin

? ? ...

? ? return 返回變量

? end;

定義一個存儲函數(shù),根據(jù)員工編號計(jì)算一個月的納稅,稅率15%

代碼:

create or replace function

? fun_getTax(vempno number) return number

is

? vtax number;

begin

? select sal*0.15 into vtax from emp where empno = vempno;

? return vtax;

end;?

調(diào)用:

declare

? vtax number;

begin

? vtax := fun_getTax(7369);

? dbms_output.put_line(vtax);

end;

打個廣告,本人博客地址是:風(fēng)吟個人博客

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末默蚌,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子旅东,更是在濱河造成了極大的恐慌混聊,老刑警劉巖季率,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件茸塞,死亡現(xiàn)場離奇詭異躲庄,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)翔横,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進(jìn)店門读跷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人禾唁,你說我怎么就攤上這事∥耷校” “怎么了荡短?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長哆键。 經(jīng)常有香客問我掘托,道長,這世上最難降的妖魔是什么籍嘹? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任闪盔,我火速辦了婚禮,結(jié)果婚禮上辱士,老公的妹妹穿的比我還像新娘泪掀。我一直安慰自己,他們只是感情好颂碘,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布异赫。 她就那樣靜靜地躺著,像睡著了一般头岔。 火紅的嫁衣襯著肌膚如雪塔拳。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天峡竣,我揣著相機(jī)與錄音靠抑,去河邊找鬼。 笑死适掰,一個胖子當(dāng)著我的面吹牛颂碧,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播攻谁,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼稚伍,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了戚宦?” 一聲冷哼從身側(cè)響起个曙,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后垦搬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體呼寸,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年猴贰,在試婚紗的時候發(fā)現(xiàn)自己被綠了对雪。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡米绕,死狀恐怖瑟捣,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情栅干,我是刑警寧澤迈套,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站碱鳞,受9級特大地震影響桑李,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜窿给,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一贵白、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧崩泡,春花似錦禁荒、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至靴寂,卻和暖如春磷蜀,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背百炬。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工褐隆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人剖踊。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓庶弃,卻偏偏與公主長得像,于是被迫代替她去往敵國和親德澈。 傳聞我的和親對象是個殘疾皇子歇攻,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評論 2 344

推薦閱讀更多精彩內(nèi)容