日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
對(duì)DB2sql存儲(chǔ)過程基礎(chǔ)的詳細(xì)解析

以下的文章主要向大家描述的是DB2 sql 存儲(chǔ)過程基礎(chǔ),存儲(chǔ)過程就是stored 簡稱為procedure。要學(xué)這個(gè)我們必須要先得弄明白另外一個(gè)概念:routine,這個(gè)一般翻譯成“例程” 。

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括北流網(wǎng)站建設(shè)、北流網(wǎng)站制作、北流網(wǎng)頁制作以及北流網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,北流網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到北流省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

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

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) 多個(gè)sql statement被調(diào)用者一次調(diào)用就能全部執(zhí)行,這能減少client和server間的數(shù)據(jù)傳輸。

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

3)能返回多個(gè)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)提供一個(gè)interface給一組sql statements。比如同時(shí)對(duì)多個(gè)表的insert操作

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

開發(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 返回?cái)?shù)據(jù)

3)INOUT: 傳入的那部分?jǐn)?shù)據(jù),在執(zhí)行過程中被返回?cái)?shù)據(jù)覆蓋

result sets:

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

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

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

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

1)declare cursor:

如:

 
 
 
  1. declare clientcur cursor with return to caller for select * from staff; 

2)open the cursor:如 open clientcur;

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

開發(fā):

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

功能:控制邏輯流向,聲明和設(shè)置變量,處理警告和異常??捎糜诶?routine),觸發(fā)器,動(dòng)態(tài)復(fù)合語句(單個(gè)調(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 :定義變量 和 定義出錯(cuò)處理

 
 
 
  1. declare sql-var-name data-type default default-values   
  2. declare condition-name condition for sqlstate value...  

 這里的condition一般做“異常”解釋

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

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

set pay = null;//空值

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

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

 
 
 
  1. set useriduserid = userid;   
  2. set today = current date;  

//同時(shí)給多個(gè)變量賦值

 
 
 
  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..  

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,需要一個(gè)label

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

signal sqlstate value set message_text = '...';//自定義一個(gè)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; 

 以上的相關(guān)內(nèi)容就是對(duì)DB2 sql 存儲(chǔ)過程基礎(chǔ)的詳細(xì)解析的介紹,望你能有所收獲。

【編輯推薦】

  1. DB2數(shù)據(jù)庫提高數(shù)據(jù)備份與恢復(fù)效率的技巧
  2. DB2數(shù)據(jù)庫日志文件進(jìn)行歸檔的問題分析
  3. DB2數(shù)據(jù)庫的安裝目錄結(jié)構(gòu)介紹
  4. DB2數(shù)據(jù)庫性能調(diào)整的命令介紹
  5. DB2數(shù)據(jù)庫開發(fā)常見問題解答

當(dāng)前文章:對(duì)DB2sql存儲(chǔ)過程基礎(chǔ)的詳細(xì)解析
URL標(biāo)題:http://www.5511xx.com/article/dhisdjo.html