成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

DB2存儲過程快速入門的“竅門”

數(shù)據(jù)庫
此文章主要介紹的是DB2存儲過程快速入門的簡便方案,以及對DB2數(shù)據(jù)庫存儲過程基本概念的描述,以下就是文章的主要內(nèi)容講述。

以下的文章主要描述的是DB2存儲過程快速入門的簡便方案,DB2數(shù)據(jù)庫存儲過程的基本概念即是stored procedure,一般都會被簡稱procedure。如果你要學(xué)這個先得弄明白另外一個概念:routine,這個一般翻譯成“例程”。

>>routine:存在server端,按應(yīng)用程序邏輯編寫的,可以通過client或者其他 routine調(diào)用的數(shù)據(jù)庫對象.

>3種類型:stored procedures,UDFs(自定義function),methods.

stored procedures:作為客戶端的擴(kuò)展但是運(yùn)行在服務(wù)端;UDFs:擴(kuò)展并且自定義SQL;methods:提供結(jié)構(gòu)化類型的行為

>2種形式:

1)sql routines:完全用sql編寫,通過create statement來注冊routine.

2)external routines:用C,C++,Java,OLE編寫,stored procedure還可用cobol編寫。任何語言編寫的都可以包含sql。

不同形式的routines可以互相調(diào)用,不管是什么語言編寫的。

再來看看stored procedure.

>>stored procedures:可以通過call statement被client或者其他routine調(diào)用;stored procedures 和它的調(diào)用程序通過create procedure statement中的參數(shù)交換數(shù)據(jù);stored procedures還能給它的調(diào)用者返回result sets.

stored procedures的優(yōu)點(diǎn):

1) 多個sql statement被調(diào)用者一次調(diào)用就能全部執(zhí)行,這能減少client和server間的數(shù)據(jù)傳輸。

2)將數(shù)據(jù)庫邏輯與應(yīng)用程序邏輯隔離開

3)能返回多個result sets

4)如果被應(yīng)用程序調(diào)用,運(yùn)行起來stored procedure就像應(yīng)用程序的一部分

缺點(diǎn):

1)不能被sql statement調(diào)用,除了用call

2)返回的結(jié)果集不能直接被sql statement使用

3)多次調(diào)用之間不能保存調(diào)用的狀態(tài),即調(diào)用之間是獨(dú)立的,無法傳遞信息。

一般的應(yīng)用之處:

1)提供一個interface給一組sql statements。比如同時對多個表的insert操作

2)標(biāo)準(zhǔn)化應(yīng)用程序邏輯(不理解,就是把db logic與app logic隔離嗎?)

DB2存儲過程之開發(fā)特性:

明白了這些基本概念后再來看看開發(fā)的特性。根據(jù)以上得知開發(fā)routine的語言有很多,這篇只講sql procedure(即sql/sql pl寫的procedure)。

>>各種語言的特性

sql:

1)效率高于java routine,基本上與c/c++ routine相當(dāng)

2)完全用sql編寫,能很快就能執(zhí)行(making them quick to implement)

3)DB2認(rèn)為sql routine是'safe'的因?yàn)槿莝ql,正因如此sql routine能直接在db engine上運(yùn)行,并且有很好的運(yùn)行效率和應(yīng)用范圍(good performance and scalability)

 

  1. >>stored procedure feathures:  
  2. parameter modes:  

 

3種類型的參數(shù):1)IN :傳入數(shù)據(jù)到stored procedure 2)OUT: stored procedure 返回數(shù)據(jù) 3)INOUT: 傳入的那部分?jǐn)?shù)據(jù),在執(zhí)行過程中被返回數(shù)據(jù)覆蓋

 

  1. result sets: 

stored procedure通過cursor來傳遞結(jié)果集給調(diào)用者。DB2存儲過程必須為每一個需要返回的結(jié)果集保留一個游標(biāo)。

>使用with return to caller/client來指定結(jié)果集返回的對象。指定為client將使得中間調(diào)用的routine不能獲得結(jié)果集,只有client才能獲得。

>使用dynamic result sets 語句來指定返回結(jié)果集的數(shù)目,這個數(shù)目保存在syscat.routines視圖的result_sets字段。如果實(shí)際返回的結(jié)果集數(shù)目大于聲明的這個數(shù)目,將發(fā)出一個warning(sqlcode +464,sqlstate 0100E)

sql stored procedure返回結(jié)果集的操作步驟:

1)declare cursor:

如:declare clientcur cursor with return to caller for select * from staff;

2)open the cursor:如 open clientcur;

3)不關(guān)閉游標(biāo)退出stored procedure

DB2存儲過程之開發(fā):

***終于來到了真正的開發(fā)了,剛才講到sql procedure是由sql,sql pl寫的,sql就沒什么好說的了。關(guān)鍵說說sql pl (procedural language)

>>功能:控制邏輯流向,聲明和設(shè)置變量,處理警告和異常。可用于例程(routine),觸發(fā)器,動態(tài)復(fù)合語句(單個調(diào)用中的sql語句塊)

>>控制語句:declare,set,for,get diagnostics,if,iterate,leave,return,signal,while

>>sql pl不能執(zhí)行的sql:table,index,view的create和drop

>>begin atomic 開頭,end 結(jié)尾

>>declare :定義變量 和 定義出錯處理

declare sql-var-name data-type default default-values

declare condition-name condition for sqlstate value... //這里的condition一般做“異常”解釋

>>set:聲明變量 和 給觸發(fā)器定義中的表中的列賦值

set pay = select salary from employee where empno = 5;//僅返回一個值

set pay = null;//空值

set pay = default;//變量定義的默認(rèn)值

//專用寄存器的內(nèi)容

set userid = userid;

set today = current date;

//同時給多個變量賦值

 

  1. set pay =10000,bonus = 1500;  
  2. set (pay,bonus) = (10000,1500);  
  3. set (pay,bonus) = select (pay,bonus) from employee where empno = 5;  
  4. >>if/then/else  

 

三種形式:

1) if then/end if 語句塊

2) if then/else/end if

3) if then/elseif /else/end if

可以在if/then/else 語句中使用sql運(yùn)算符,如:

 

  1. if (salary between 10000 and 90000) then...  
  2. if (deptno in ('a00','b01')) then..  
  3. if (exist (select * from employee)) then...  
  4. if (select count(*) from employee)>0) then..  
  5. >>while  
  6. label:  
  7. while condition do  
  8. ...sql pl ..  
  9. end while lable;   

label可選

>>for:用于循環(huán)select返回結(jié)果集的行

格式:

 

  1. label:  
  2. for row_label as select satement do  
  3. ..sql pl..  
  4. end for label;  

label可選

例子:

 

  1. for emp as select * from employee where bonus >1000 do  
  2. set total_bonustotal_bonus = total_bonus +emp.bonus;  
  3. end for;  

 

>>iterate:用來回到for或者while循環(huán)的開始重新執(zhí)行

 

  1. check_bonus:   
  2. for emp as select * from employee do  
  3. if(emp.bonus>10000) then  
  4. set total_bonustotal_bonus = total_bonus +emp.bonus;  
  5. else  
  6. iterate check_bonus;  
  7. end if;  
  8. end for check_bonus;  

 

>>leave:相當(dāng)于java中的break,需要一個label

>>signal:對出現(xiàn)異常的應(yīng)用程序報警

signal sqlstate value set message_text = '...';//自定義一個sqlstate,7、8、9和I~Z開頭的sqlstate

signal condition set message_text = '...';//自定義異常condition

>>get diagnostics:用在sql pl觸發(fā)器或語句塊(不是函數(shù))內(nèi),返回update,insert,delete語句影響的記錄數(shù)。

 

  1. get diagnostics variable = row_count

如果你還不很熟悉DB2存儲過程,那么讀完此文章你將收獲很大的。

【編輯推薦】

  1. DB2性能調(diào)優(yōu)中易出現(xiàn)的問題有哪些?
  2. DB2***SQL性能調(diào)節(jié)技術(shù)經(jīng)典版
  3. IBM DB2數(shù)據(jù)庫與注意事項(xiàng)_DB2編程的描述
  4. DB2 并行版本中的查詢優(yōu)化登峰造極!
  5. DB2數(shù)據(jù)庫進(jìn)行備份在AIX如何操作?
     
責(zé)任編輯:佚名 來源: 51cto.com
相關(guān)推薦

2010-08-18 13:59:04

DB2純SQL存儲過程

2011-05-16 14:52:19

DB2 9 Viper

2010-11-03 10:35:45

DB2存儲過程

2010-11-03 10:26:22

DB2存儲過程

2010-11-03 10:46:49

DB2存儲過程

2010-08-31 15:39:25

DB2存儲過程

2010-08-05 10:42:33

DB2 拉鏈表存儲過程

2010-08-25 09:56:02

DB2存儲過程

2010-11-04 12:00:59

db2存儲過程

2011-04-15 13:21:41

DB2翻頁存儲

2010-07-30 09:57:31

2010-08-06 17:52:17

DB2未使用索引

2010-09-06 10:54:52

DB2 sql 存儲過

2010-11-03 11:02:34

DB2存儲過程

2009-03-10 09:08:06

DB2存儲過程實(shí)施

2010-09-01 15:09:41

DB2動態(tài)游標(biāo)

2010-09-06 10:43:15

DB2 SQL存儲過程

2010-08-26 11:37:38

DB2命令

2010-08-04 09:56:44

2010-08-10 10:01:39

DB2數(shù)據(jù)庫備份
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 欧美成年网站 | 欧美黄在线观看 | 国产视频一区在线 | 国产乱人伦 | 99精品久久久久久久 | 精品1区2区3区 | 久久久精品视频一区二区三区 | 国产精品久久久久久中文字 | 日韩二三区 | 91精品久久久久久久久中文字幕 | 欧美午夜视频 | 国产高清在线视频 | 欧美综合在线视频 | 中文字幕一区在线观看视频 | 国产精品美女在线观看 | 久久久久91 | 亚洲精品免费观看 | 动漫www.被爆羞羞av44 | 欧美a在线| 免费一级做a爰片久久毛片潮喷 | 亚洲成人网在线播放 | 99草免费视频 | 91精品在线看 | 韩国成人在线视频 | 国产精品免费大片 | 精品国产一区二区国模嫣然 | 精品一区二区三区免费视频 | av中文字幕在线播放 | 国产精品有限公司 | 中文字幕在线观看视频一区 | 色眯眯视频在线观看 | 国产午夜亚洲精品不卡 | 一级片成人 | 欧美日韩高清一区 | 久久伦理电影 | 欧美性一级 | 国产精品久久久久久久久久久新郎 | 91在线免费视频 | 午夜视频一区二区 | 亚洲精品久久久一区二区三区 | 日韩一区二区在线播放 |