存儲函數(shù)

存儲函數(shù)

  • 創(chuàng)建無參存儲函數(shù)get_name,有返回值
    語法:
create or replace function 函數(shù)名  return 返回類型 as PLSQL程序段
create or replace function get_name return varchar2
as
begin
  return'哈哈';
end;
  • 刪除存儲函數(shù)getName
    語法:
drop function 函數(shù)名
  • 調(diào)用存儲方式一,PLSQL程序
declare 
  name varchar2(10);
begin
  name:=get_name;
  dbms_output.put_line('姓名是:'||name);
end;
  • 調(diào)用存儲方式二,java程序
    創(chuàng)建由有參存儲函數(shù)findEmpIncome(編號),查詢7499號員工的年收入俏险,演示in的用法,默認(rèn)in
--定義函數(shù)
create  or replace function findEmpIncome(p_empno emp.empno%type) return number
as
 income number;
begin
 select sal*12 into income from emp where empno=p_empno;
 return income;
end;

--調(diào)用函數(shù)
declare 
 income number;
begin
 income:=findEmpIncome(7499);
   dbms_output.put_line('該員工年收入為:'||income);
end;
--創(chuàng)建有參存儲函數(shù)findEmpNameAndJobAndSal(編號)扬绪,查詢7499號員工的姓名(return),職位(out),月薪(out),返回多個(gè)值
--創(chuàng)建函數(shù)
create or replace function findEmpNameAndJobAndSal(p_empno in number,p_job out varchar2,p_sal out number)
return varchar2
as
  p_ename emp.ename%type;
begin
  select ename,job,sal into p_ename,p_job,p_sal from emp where empno=p_empno;
  return p_ename;
end;
--調(diào)用函數(shù)
declare 
p_ename emp.ename%type;
p_job emp.job%type;
p_sal emp.sal%type;
val varchar2(255);
begin
  val:= findEmpNameAndJobAndSal(7499,p_job,p_sal);
  dbms_output.put_line('7499'||p_ename||'----'||p_job||'----'||p_sal);
end;

存儲過程:無返回值或者有多個(gè)返回值時(shí)竖独,適合用過程。
存儲函數(shù):有且只有一個(gè)返回值時(shí)挤牛,適合用函數(shù)莹痢。
適合使用過程函數(shù)的情況:

  1. 需要長期保存在數(shù)據(jù)庫中。
  2. 需要被多個(gè)用戶同時(shí)使用墓赴。
  3. 批操作大量數(shù)據(jù)竞膳,例如批插入多條數(shù)據(jù)。

適合使用SQL的情況:

  1. 凡是上述反面诫硕,都可使用SQL坦辟。
  2. 對表、視圖章办、序列锉走、索引等這些,適合用SQL藕届。

向emp表中插入999條記錄挪蹭,寫成過程的形式。

--創(chuàng)建過程
create or replace procedure   batchInsert
as
  i number(4):=1;
begin
  for i in 1..999
  loop
    insert into emp(empno,ename) values (i,'測試');
  end loop;
end;
--調(diào)用過程
exec batchInsert;

函數(shù)版本的個(gè)人所得稅

create or replace function getrax(sal in number,rax out number) return number
as
  --sal表示收入
  --bal表示需要繳稅的收入
  bal number;
begin
  bal:=sal-3500;
  if bal<=1500 then
    rax:=bal*0.03-0;
  elsif bal<4500 then
    rax:=bal*0.1-105;
  elsif bal<9000 then
    rax:=bal*0.2-555;
  elsif bal<35000 then
    rax:=bal*0.3-2775;
  elsif bal<80000 then
    rax:=bal*0.45-5505;
  else
    rax:=bal*0.45-13505;
  end if;
  return bal;
end;
--調(diào)用過程
declare
  rax number;
  who number;
begin
  who:=getrax(&sal,rax);
  dbms_output.put_line('您需要交的稅'||rax);
end;
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末休偶,一起剝皮案震驚了整個(gè)濱河市梁厉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌踏兜,老刑警劉巖词顾,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件只冻,死亡現(xiàn)場離奇詭異,居然都是意外死亡计技,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進(jìn)店門山橄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來垮媒,“玉大人,你說我怎么就攤上這事航棱∷停” “怎么了?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵饮醇,是天一觀的道長它抱。 經(jīng)常有香客問我,道長朴艰,這世上最難降的妖魔是什么观蓄? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮祠墅,結(jié)果婚禮上侮穿,老公的妹妹穿的比我還像新娘。我一直安慰自己毁嗦,他們只是感情好亲茅,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著狗准,像睡著了一般克锣。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上腔长,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天袭祟,我揣著相機(jī)與錄音,去河邊找鬼饼酿。 笑死榕酒,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的故俐。 我是一名探鬼主播想鹰,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼药版!你這毒婦竟也來了辑舷?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤槽片,失蹤者是張志新(化名)和其女友劉穎何缓,沒想到半個(gè)月后肢础,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡碌廓,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年传轰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片谷婆。...
    茶點(diǎn)故事閱讀 39,926評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡慨蛙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出纪挎,到底是詐尸還是另有隱情期贫,我是刑警寧澤,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布异袄,位于F島的核電站通砍,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏烤蜕。R本人自食惡果不足惜封孙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望玖绿。 院中可真熱鬧敛瓷,春花似錦、人聲如沸斑匪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蚀瘸。三九已至狡蝶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間贮勃,已是汗流浹背贪惹。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留寂嘉,地道東北人奏瞬。 一個(gè)月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像泉孩,于是被迫代替她去往敵國和親硼端。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評論 2 354

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

  • 當(dāng)一個(gè)大型系統(tǒng)在建立時(shí)寓搬,會發(fā)現(xiàn)珍昨,很多的SQL操作是有重疊的,個(gè)別計(jì)算是相同的,比如:業(yè)務(wù)系統(tǒng)中镣典,計(jì)算一張工單的計(jì)算...
    JackFrost_fuzhu閱讀 3,380評論 0 27
  • 一. 存儲過程和存儲函數(shù)的定義 定義:存儲在數(shù)據(jù)庫中兔毙,供所有用戶程序調(diào)用的子程序叫做存儲過程/存儲函數(shù)。復(fù)雜點(diǎn)的解...
    GuangHui閱讀 10,503評論 0 22
  • 根據(jù)慕課網(wǎng)課程Oracle存儲過程和自定義函數(shù)整理 1.概念 (1)定義:存儲在數(shù)據(jù)庫中供所有用戶程序調(diào)用的子程序...
    shenby閱讀 353評論 0 0
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法兄春,類相關(guān)的語法澎剥,內(nèi)部類的語法,繼承相關(guān)的語法赶舆,異常的語法肴裙,線程的語...
    子非魚_t_閱讀 31,631評論 18 399
  • 一、查看幫助文檔 在學(xué)習(xí)編程語言過程中涌乳,不管是python語言還是其它語言時(shí)我們應(yīng)學(xué)會查看API文檔,查看幫助信息...
    轉(zhuǎn)身后的那一回眸閱讀 456評論 0 0