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

            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 閱讀(249) 評論(0)  編輯 收藏 引用 所屬分類: DB2
            DB2 sql存儲過程基礎(chǔ) 原帖發(fā)于:http://eyejava.javaeye.com/blog/32263

            基本概念:
            存儲過程即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隔離嗎?)

            開發(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 返回數(shù)據(jù) 3)INOUT: 傳入的那部分?jǐn)?shù)據(jù),在執(zhí)行過程中被返回數(shù)據(jù)覆蓋

            result sets:
            stored procedure通過cursor來傳遞結(jié)果集給調(diào)用者。存儲過程必須為每一個需要返回的結(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

            開發(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;
            //同時給多個變量賦值
            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,需要一個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ù)。
            get diagnostics variable = row_count;
            久久精品夜色噜噜亚洲A∨| 久久91精品国产91久| 国产产无码乱码精品久久鸭| 久久久久亚洲av无码专区喷水| 久久久久亚洲精品天堂| 99久久婷婷国产一区二区| 久久亚洲中文字幕精品一区| 久久久久久国产精品无码下载| 亚洲国产精品无码久久久蜜芽| 99精品国产在热久久无毒不卡| 色综合久久天天综合| 欧美亚洲国产精品久久| 久久精品中文字幕无码绿巨人| 久久伊人影视| 国产精品久久久久久影院| 久久这里的只有是精品23| 2021少妇久久久久久久久久| 久久强奷乱码老熟女网站 | 青青草原综合久久大伊人| 久久久久高潮毛片免费全部播放| 国产精品热久久无码av| 亚洲va久久久噜噜噜久久天堂 | 久久久久国产一级毛片高清板| 亚洲日本va中文字幕久久| 久久久噜噜噜久久| 久久久久久久综合日本亚洲| 亚洲中文字幕久久精品无码喷水| 久久国产视频99电影| 国产精品一区二区久久精品| 久久亚洲私人国产精品vA| 久久强奷乱码老熟女网站| 久久亚洲国产最新网站| 久久久久久久久久免免费精品| 亚洲精品高清国产一久久| 九九久久99综合一区二区| 欧美亚洲色综久久精品国产| 久久久无码精品亚洲日韩蜜臀浪潮 | 亚洲欧美精品一区久久中文字幕| 中文精品久久久久国产网址| AAA级久久久精品无码片| 久久国产精品成人影院|