青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Prayer

在一般中尋求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

DB2 sql存儲過程基礎 (轉)

Posted on 2010-05-09 18:32 Prayer 閱讀(255) 評論(0)  編輯 收藏 引用 所屬分類: DB2
DB2 sql存儲過程基礎 原帖發于:http://eyejava.javaeye.com/blog/32263

基本概念:
存儲過程即stored procedure,一般會被簡稱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)
>>stored procedure feathures:
parameter modes:
3種類型的參數:1)IN :傳入數據到stored procedure 2)OUT: stored procedure 返回數據 3)INOUT: 傳入的那部分數據,在執行過程中被返回數據覆蓋

result sets:
stored procedure通過cursor來傳遞結果集給調用者。存儲過程必須為每一個需要返回的結果集保留一個游標。
>使用with return to caller/client來指定結果集返回的對象。指定為client將使得中間調用的routine不能獲得結果集,只有client才能獲得。
>使用dynamic result sets 語句來指定返回結果集的數目,這個數目保存在syscat.routines視圖的result_sets字段。如果實際返回的結果集數目大于聲明的這個數目,將發出一個warning(sqlcode +464,sqlstate 0100E)
sql stored procedure返回結果集的操作步驟:
1)declare cursor:
如:declare clientcur cursor with return to caller for select * from staff;
2)open the cursor:如 open clientcur;
3)不關閉游標退出stored procedure

開發:
最后終于來到了真正的開發了,剛才講到sql procedure是由sql,sql pl寫的,sql就沒什么好說的了。關鍵說說sql pl (procedural language)
>>功能:控制邏輯流向,聲明和設置變量,處理警告和異常。可用于例程(routine),觸發器,動態復合語句(單個調用中的sql語句塊)
>>控制語句:declare,set,for,get diagnostics,if,iterate,leave,return,signal,while
>>sql pl不能執行的sql:table,index,view的create和drop
>>begin atomic 開頭,end 結尾
>>declare :定義變量 和 定義出錯處理
declare sql-var-name data-type default default-values
declare condition-name condition for sqlstate value... //這里的condition一般做“異常”解釋
>>set:聲明變量 和 給觸發器定義中的表中的列賦值
set pay = select salary from employee where empno = 5;//僅返回一個值
set pay = null;//空值
set pay = default;//變量定義的默認值
//專用寄存器的內容
set userid = userid;
set today = current date;
//同時給多個變量賦值
set pay =10000,bonus = 1500;
set (pay,bonus) = (10000,1500);
set (pay,bonus) = select (pay,bonus) from employee where empno = 5;
>>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運算符,如:
if (salary between 10000 and 90000) then...
if (deptno in ('a00','b01')) then..
if (exist (select * from employee)) then...
if (select count(*) from employee)>0) then..
>>while
label:
while condition do
...sql pl ..
end while lable; //label可選
>>for:用于循環select返回結果集的行
格式:
label:
for row_label as select satement do
..sql pl..
end for label;//label可選
例子:
for emp as select * from employee where bonus >1000 do
set total_bonus = total_bonus +emp.bonus;
end for;
>>iterate:用來回到for或者while循環的開始重新執行
check_bonus:
for emp as select * from employee do
if(emp.bonus>10000) then
set total_bonus = total_bonus +emp.bonus;
else
iterate check_bonus;
end if;
end for check_bonus;
>>leave:相當于java中的break,需要一個label

>>signal:對出現異常的應用程序報警
signal sqlstate value set message_text = '...';//自定義一個sqlstate,7、8、9和I~Z開頭的sqlstate
signal condition set message_text = '...';//自定義異常condition

>>get diagnostics:用在sql pl觸發器或語句塊(不是函數)內,返回update,insert,delete語句影響的記錄數。
get diagnostics variable = row_count;
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            性欧美videos另类喷潮| 久久不射中文字幕| 亚洲欧美另类久久久精品2019| 亚洲欧洲一二三| 亚洲日本一区二区三区| 亚洲精品专区| 亚洲一区在线直播| 午夜久久久久久| 久久久av水蜜桃| 久久亚洲一区二区三区四区| 蜜桃av一区二区三区| 欧美二区在线看| 亚洲蜜桃精久久久久久久| 亚洲美女中文字幕| 亚洲免费在线播放| 久久久久久久久蜜桃| 免播放器亚洲| 国产精品美腿一区在线看| 国产一区二区日韩精品| 亚洲人午夜精品免费| 亚洲一区二区在线| 国产精品99免费看| 激情成人在线视频| 一区二区三区 在线观看视| 欧美亚洲一区三区| 亚洲高清视频中文字幕| 欧美电影在线观看完整版| 亚洲日韩视频| 亚洲欧美美女| 欧美久久久久久蜜桃| 国产一区二区中文| 亚洲视屏在线播放| 欧美激情小视频| 欧美一级夜夜爽| 欧美特黄a级高清免费大片a级| 狠狠色丁香久久婷婷综合_中| 亚洲性xxxx| 亚洲国产毛片完整版| 午夜欧美精品| 国产精品国产三级国产普通话三级 | 99pao成人国产永久免费视频| 亚洲欧美视频一区二区三区| 蜜臀av在线播放一区二区三区| 夜夜嗨一区二区| 另类春色校园亚洲| 国产日韩在线一区二区三区| 亚洲视频精选| 亚洲激情视频网| 免费成人黄色av| 国内揄拍国内精品久久| 亚洲欧美日韩视频一区| 亚洲精品视频免费观看| 久久久噜久噜久久综合| 国产欧美不卡| 亚洲男女毛片无遮挡| 亚洲精品国产拍免费91在线| 久久久久成人精品免费播放动漫| 国产精品入口麻豆原神| 亚洲一区二区精品在线| 亚洲精品五月天| 欧美美女福利视频| 99视频国产精品免费观看| 欧美激情影院| 久久亚洲高清| 亚洲国产一区二区a毛片| 久久阴道视频| 狼人天天伊人久久| 亚洲国产日韩一级| 亚洲高清在线视频| 欧美激情在线| 亚洲综合999| 亚洲欧美日韩久久精品| 国产欧美在线播放| 亚洲网址在线| 在线视频精品一| 欧美视频国产精品| 亚洲欧美韩国| 欧美一区二区视频网站| 精品999在线观看| 亚洲成人在线视频播放| 欧美激情视频在线播放| 一区二区高清在线| 亚洲女爱视频在线| 在线播放中文字幕一区| 亚洲人成人一区二区在线观看 | 久久精品女人天堂| 在线播放中文一区| 99视频精品全部免费在线| 国产精品视频xxxx| 蜜臀久久99精品久久久久久9| 欧美国产先锋| 香蕉国产精品偷在线观看不卡| 亚洲欧美国产77777| 亚洲国产高潮在线观看| 日韩视频在线观看| 国产在线精品一区二区中文| 91久久久国产精品| 国产精品日日做人人爱| 欧美成人久久| 国产精品日韩精品欧美在线 | 日韩手机在线导航| 国产精品影院在线观看| 欧美va天堂| 国产精品久久久久9999| 老牛国产精品一区的观看方式| 欧美女同视频| 久久影院午夜论| 欧美日韩国语| 免费在线日韩av| 国产精品国产三级国产普通话99| 老色鬼久久亚洲一区二区| 欧美日精品一区视频| 麻豆精品在线播放| 国产精品二区二区三区| 欧美高清视频免费观看| 国产欧美亚洲视频| 99国产精品国产精品久久| 国语精品中文字幕| 亚洲性视频网站| 一二三四社区欧美黄| 久久激情网站| 欧美在线观看网站| 欧美日韩一区在线观看| 欧美激情精品久久久久| 国产一区二区三区四区老人| 99riav1国产精品视频| 亚洲人成人99网站| 午夜一级在线看亚洲| 亚洲一区二区在线播放| 欧美大片国产精品| 欧美成人精品在线| 国内精品免费在线观看| 午夜国产精品影院在线观看| 亚洲一区二区三区乱码aⅴ| 99精品国产在热久久下载| 久久人人看视频| 国产精品视频精品视频| 亚洲精选视频在线| 日韩亚洲视频在线| 欧美电影免费观看高清完整版| 免费欧美高清视频| 激情亚洲一区二区三区四区| 欧美亚洲综合在线| 久久精品国产一区二区三| 国产老肥熟一区二区三区| 亚洲一区国产一区| 欧美在线观看视频在线| 国产一区二区三区四区五区美女| 午夜精品一区二区在线观看| 亚洲欧美韩国| 国产精品影音先锋| 欧美中文字幕视频| 麻豆精品传媒视频| 亚洲黄色免费电影| 欧美日韩国产综合久久| 中日韩午夜理伦电影免费| 午夜欧美理论片| 黑人一区二区| 欧美激情aaaa| 亚洲尤物在线| 免费在线观看成人av| 亚洲精品一线二线三线无人区| 欧美激情一区| 亚洲欧美bt| 欧美高清在线观看| 亚洲午夜黄色| 在线观看亚洲视频| 欧美日韩国产欧| 亚洲综合国产| 欧美激情第10页| 国产精品99久久久久久www| 校园春色综合网| 1000部国产精品成人观看 | 欧美激情视频一区二区三区免费 | 蜜臀av性久久久久蜜臀aⅴ四虎| 99人久久精品视频最新地址| 欧美一区二区三区四区在线| 一区二区三区在线观看视频| 欧美成人精品h版在线观看| 在线亚洲欧美视频| 男人天堂欧美日韩| 亚洲视频在线一区观看| 国产麻豆视频精品| 欧美二区不卡| 欧美综合国产精品久久丁香| 亚洲欧洲精品一区二区| 久久精品国产一区二区三| 欧美一区二区三区另类| 亚洲精品自在在线观看| 免费久久99精品国产| 午夜在线a亚洲v天堂网2018| 亚洲国产日韩综合一区| 国产欧美欧美| 欧美日韩一区二区三区在线看| 久久精品国内一区二区三区| 一本一本久久a久久精品综合妖精| 麻豆成人综合网| 久久精品日产第一区二区三区| 这里只有精品丝袜| 亚洲精品激情|