程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> DB2數據庫 >> DB2教程 >> 對DB2 sql 存儲過程基礎的詳細解析(1)

對DB2 sql 存儲過程基礎的詳細解析(1)

編輯:DB2教程

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

routine:存在server端,按應用程序邏輯編寫的,可以通過clIEnt或者其他routine調用的數據庫對象.

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

stored procedures:作為客戶端的擴展但是運行在服務端;UDFs:擴展並且自定義SQL;methods:提供結構化類型的行為

2種形式:

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

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

不同形式的routines可以互相調用,不管是什麼語言編寫的。

再來看看stored procedure.

stored procedures:可以通過call statement被clIEnt或者其他routine調用;stored procedures 和它的調用程序通過create procedure statement中的參數交換數據;stored procedures還能給它的調用者返回result sets.

stored procedures的優點:

1) 多個sql statement被調用者一次調用就能全部執行,這能減少clIEnt和server間的數據傳輸。

2)將數據庫邏輯與應用程序邏輯隔離開

3)能返回多個result sets

4)如果被應用程序調用,運行起來stored procedure就像應用程序的一部分

缺點:

1)不能被sql statement調用,除了用call

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

3)多次調用之間不能保存調用的狀態,即調用之間是獨立的,無法傳遞信息。

一般的應用之處:

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

2)標准化應用程序邏輯(不理解,就是把db logic與app logic隔離嗎?)

開發特性:

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

各種語言的特性

sql:

1)效率高於Java routine,基本上與c/c++ routine相當

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

3)DB2認為sql routine是'safe'的因為全是sql,正因如此sql routine能直接在db engine上運行,並且有很好的運行效率和應用范圍(good performance and scalability)

  1. stored procedure feathures:   
  2. parameter modes: 

3種類型的參數:

1)IN :傳入數據到stored procedure

2)OUT: stored procedure 返回數據

3)INOUT: 傳入的那部分數據,在執行過程中被返回數據覆蓋

result sets:

stored procedure通過cursor來傳遞結果集給調用者。DB2 sql 存儲過程必須為每一個需要返回的結果集保留一個游標。

使用with return to caller/client來指定結果集返回的對象。指定為client將使得中間調用的routine不能獲得結果集,只有clIEnt才能獲得。

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved