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

Prayer

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

DB2 sql存儲過程基礎(chǔ) (轉(zhuǎn))

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

基本概念:
存儲過程即stored procedure,一般會被簡稱procedure。要學(xué)這個(gè)先得弄明白另外一個(gè)概念:routine,這個(gè)一般翻譯成“例程”
>>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) 多個(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í)對多個(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)
>>stored procedure feathures:
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)用者。存儲過程必須為每一個(gè)需要返回的結(jié)果集保留一個(gè)游標(biāo)。
>使用with return to caller/client來指定結(jié)果集返回的對象。指定為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)
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

開發(fā):
最后終于來到了真正的開發(fā)了,剛才講到sql procedure是由sql,sql pl寫的,sql就沒什么好說的了。關(guān)鍵說說sql pl (procedural language)
>>功能:控制邏輯流向,聲明和設(shè)置變量,處理警告和異常。可用于例程(routine),觸發(fā)器,動態(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ò)處理
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;//僅返回一個(gè)值
set pay = null;//空值
set pay = default;//變量定義的默認(rèn)值
//專用寄存器的內(nèi)容
set userid = userid;
set today = current date;
//同時(shí)給多個(gè)變量賦值
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運(yùn)算符,如:
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:用于循環(huán)select返回結(jié)果集的行
格式:
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循環(huán)的開始重新執(zhí)行
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:相當(dāng)于java中的break,需要一個(gè)label

>>signal:對出現(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ù)。
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>
            国产精品r级在线| 日韩视频一区二区在线观看 | 久久婷婷激情| 久久精品综合| 久久夜色精品亚洲噜噜国产mv| 久久精品视频在线播放| 麻豆免费精品视频| 欧美激情2020午夜免费观看| 亚洲精品欧美精品| 亚洲欧美色婷婷| 久久精品国亚洲| 欧美激情导航| 国产噜噜噜噜噜久久久久久久久| 国产一区二区0| 亚洲三级影片| 一区二区三区回区在观看免费视频| 亚洲免费视频中文字幕| 久久精品人人做人人爽电影蜜月| 男同欧美伦乱| 这里只有精品在线播放| 久久久久久久性| 欧美日韩一区在线| 国外成人在线视频网站| 亚洲精品影院| 久久精品九九| 一区二区三区免费在线观看| 久久精品国产亚洲aⅴ| 欧美精品午夜视频| 欧美主播一区二区三区美女 久久精品人 | 欧美激情在线免费观看| 国产精品久久毛片a| 国产亚洲欧洲997久久综合| 亚洲欧洲日韩综合二区| 久久大综合网| 亚洲精品美女免费| 一区二区三区四区五区精品视频| 欧美一区二区黄色| 欧美日韩一区二区精品| 亚洲大胆美女视频| 欧美专区一区二区三区| 日韩视频免费| 欧美福利一区| 在线不卡a资源高清| 欧美在线观看视频一区二区三区 | 亚洲电影免费观看高清| 国产精品二区三区四区| 欧美伦理91| 亚洲高清免费视频| 久久不射电影网| 亚洲视频1区2区| 欧美激情bt| 欧美一区二区三区精品| 欧美视频在线观看一区二区| 亚洲国产午夜| 久久综合九色综合网站| 亚洲午夜在线| 国产精品久久久久久久久借妻 | 久久精品中文字幕一区| 夜夜嗨av一区二区三区网页| 久久综合九色九九| 在线观看成人小视频| 久久久久久久久久久成人| 亚洲在线1234| 国产亚洲精品自拍| 久久裸体艺术| 久久久精品一品道一区| 伊人色综合久久天天五月婷| 免费视频一区| 欧美wwwwww| 在线一区二区三区四区五区| 夜夜嗨av一区二区三区四季av| 欧美视频第二页| 香蕉国产精品偷在线观看不卡| 亚洲一区二区黄色| 国内精品久久久久久久影视麻豆| 日韩视频在线一区二区| 亚洲三级网站| 国产精品v日韩精品| 羞羞答答国产精品www一本| 亚洲欧美日韩成人高清在线一区| 国产精品一区二区三区四区五区| 午夜久久久久久| 久久不射中文字幕| 亚洲高清成人| 亚洲免费电影在线| 国产日韩欧美在线看| 久久综合久久综合久久| 欧美激情aaaa| 欧美一区二区免费| 蜜臀av性久久久久蜜臀aⅴ| 99国产精品久久久久久久久久 | 欧美在线视频a| 久久免费国产| 亚洲精品乱码久久久久久蜜桃91| 亚洲日本va午夜在线影院| 国产精品男女猛烈高潮激情| 久久久欧美一区二区| 欧美黄污视频| 久久久亚洲人| 欧美日韩天堂| 欧美成年人视频网站欧美| 国产精品国产三级国产专区53 | 久久天堂国产精品| 一区二区三区国产精华| 久久精品国产清高在天天线| 一区二区高清视频| 久久久久一区| 亚洲综合欧美日韩| 欧美成人一区二区三区在线观看| 欧美在线免费| 欧美少妇一区二区| 欧美国产成人在线| 国产视频久久久久久久| 日韩亚洲精品电影| 亚洲黄网站在线观看| 欧美亚洲午夜视频在线观看| 一个人看的www久久| 裸体歌舞表演一区二区| 欧美中在线观看| 国产精品xxxav免费视频| 欧美国产日本| 黄网站色欧美视频| 午夜精品在线看| 亚洲欧美日韩系列| 欧美日韩国产高清| 亚洲青色在线| 亚洲欧洲日产国产综合网| 久久精品在这里| 久久久久久久久岛国免费| 国产精品午夜电影| 亚洲视频网站在线观看| 国外成人性视频| 午夜精品一区二区三区在线| 亚洲天堂av在线免费| 欧美人妖在线观看| 亚洲国产日韩一区二区| 亚洲日本中文字幕免费在线不卡| 久久久91精品国产| 久热成人在线视频| 影音先锋在线一区| 久久综合给合久久狠狠色| 欧美成ee人免费视频| 亚洲国产一二三| 欧美大成色www永久网站婷| 亚洲第一精品电影| 亚洲日本中文字幕| 欧美日韩精品免费在线观看视频| 亚洲精品综合精品自拍| 亚洲一区二区免费看| 国产精品一区免费视频| 午夜亚洲福利在线老司机| 卡一卡二国产精品| 日韩一区二区精品在线观看| 欧美日韩在线电影| 午夜视频在线观看一区| 免费成人高清在线视频| 亚洲精品日韩欧美| 国产精品久久久久久一区二区三区 | 国产午夜亚洲精品羞羞网站| 欧美伊人久久久久久午夜久久久久| 久久精品一二三| 亚洲国产一区二区精品专区| 久久高清免费观看| 欧美国产日韩视频| 亚洲一区二区av电影| 国产精品一区一区| 久热精品视频在线免费观看 | 欧美一区二区三区男人的天堂| 久久久久久亚洲精品不卡4k岛国| 禁久久精品乱码| 欧美日本在线视频| 午夜精品国产更新| 欧美a级在线| 亚洲午夜久久久| 国产一区二区三区免费不卡 | 欧美午夜久久久| 欧美一区二区私人影院日本 | 久久看片网站| 夜夜夜精品看看| 开心色5月久久精品| 亚洲天堂黄色| 亚洲高清网站| 国产美女精品一区二区三区| 农夫在线精品视频免费观看| 亚洲综合社区| 最新中文字幕亚洲| 久久精品免费观看| 亚洲在线一区二区| 亚洲毛片一区| 亚洲国产成人久久综合一区| 久色婷婷小香蕉久久| 亚洲伊人观看| 99re8这里有精品热视频免费 | 久久精品成人| 亚洲综合精品| 在线亚洲一区二区| 亚洲精品日韩激情在线电影| 激情成人中文字幕| 国产综合网站| 国产日韩精品一区二区三区在线 |