版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、第一節(jié)程序塊結(jié)構(gòu)語言PL/SQL的組成PL/SQL塊的組成PL/SQL 一個基本的PL/SQL塊由3部分組成:定義部分(DECLARE),可執(zhí)行部分(BEGIN),異常處理部分(EXCEPTION)。 1第二節(jié) 代碼塊的基本結(jié)構(gòu)PL/SQL代碼塊的最小結(jié)構(gòu)是由一個begin和一個end,以及這二者之間的一條可執(zhí)行的命令組成Declare Begin Null; End;Declare Begin -Null; End;2Declare -定義變量 begin -sql語句 -pl/sql塊 exception -異常處理 end; 3DECLARE V_VARIABLE VARCHAR2(10
2、);BEGIN SELECT AAA100 INTO V_VARIABLE FROM AA10 WHERE AAA102 = 02;DBMS_OUTPUT.PUT_LINE(V_VARIABLE的值為: | V_VARIABLE);EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE(查詢表AA10 出錯,出錯原因?yàn)椋?| SQLERRM);END;4在PL/SQL中處理變量在定義部分定義和初始化變量在執(zhí)行部分給變量賦新值通過參數(shù)在PL/SQL塊之間傳遞值通過輸出變量查看結(jié)果5定義PL/SQL變量語法:identifier CONSTANT datat
3、ype NOT NULL := | DEFAULT expr;例子:Declare v_hiredateDATE; v_deptnoNUMBER(2) NOT NULL := 10; v_locationVARCHAR2(13) := shanghai; c_commCONSTANT NUMBER := 1400;6定義變量指導(dǎo)方針在PL/SQL中使用的變量、常量、游標(biāo)和異常處理的名字都必須先定義后使用。定義部分是包括在關(guān)鍵字DECLARE和BEGIN之間的部分,每條語句后用;結(jié)束。指定NOT NULL強(qiáng)制初始化變量使用:=或DEFAULT可以初始化變量每行只能定義一個變量如果加上關(guān)鍵字CON
4、STANT,則表示所定義的標(biāo)識符為一個常量,必須為它賦初值。變量的命名規(guī)則與SQL的規(guī)則基本相同,即每個標(biāo)識符必須以字母開頭,而且不分大小寫。如果定義的標(biāo)識符不能為空,則必須加上關(guān)鍵字NOT NULL,并賦初值。7命名規(guī)則不同塊的變量可以同名變量名不應(yīng)該與表列同名8給變量賦值語法:Identifier := expr;例子:V_hiredate := 2007-03-26;V_name := TOM;9常用數(shù)據(jù)類型:VARCHAR2 (maximum_length)NUMBER (precision, scale)DATECHAR (maximum_length)LONGBOOLEANBINA
5、RY_INTEGERPLS_INTEGER 例子 : v_jobVARCHAR2(9); v_countBINARY_INTEGER := 0; v_total_salNUMBER(9,2) := 0; v_orderdateDATE := SYSDATE + 7; c_tax_rateCONSTANT NUMBER(3,2) := 8.25; v_validBOOLEAN NOT NULL := TRUE;10%TYPE屬性按照表列或先前變量定義新變量%TYPE前需要帶有前綴:表和列先前定義的變量名11例:DECLAREteacher_name char(5);student_name te
6、acher_name%TYPE;BEGINENDDECLAREno EMP.EMPNO%TYPE;BEGIN End;12聲明一個記錄型變量,使它的類型與某個基本表的數(shù)據(jù)結(jié)構(gòu)一致,可以使用%ROWTYPE的形式定義。DECLAREEMP_VALUE EMP%ROWTYPE;BEGIN引用方式: EMP_VALUE .empno EMP_VALUE .ename13定義BOOLEAN變量只能將 TRUE、FALSE和NULL賦給布爾變量布爾變量用邏輯操作符AND、OR和NOT連接算術(shù)、字符和日期表達(dá)式可用于返回布爾值例子: DECLARE V_BBB BOOLEAN;BEGIN V_BBB :=
7、 TRUE; IF V_BBB = TRUE THEN DBMS_OUTPUT.PUT_LINE(aaaa); END IF;END;14小結(jié)PL/SQL 塊由以下三部分組成: 定義部分(可選)執(zhí)行部分(必須)異常處理部分(可選)PL/SQL 塊的匿名塊的編寫: PL/SQL 塊中常用變量的定義及附值:15替代變量以&開頭,&號后面可以根數(shù)字或字符例子: DECLARE V_AVGSAL VARCHAR(20);BEGIN V_AVGSAL := &4566; DBMS_OUTPUT.PUT_LINE(your enter is: | V_AVGSAL);END;16例子2:DECLARE V
8、_AVGSAL varchar(20);BEGIN SELECT AAA100 INTO V_AVGSAL FROM AA10 WHERE AA10.AAA102 = &NO AND ROWNUM = 1; DBMS_OUTPUT.PUT_LINE(value aaa100 is: | V_AVGSAL);END;17練習(xí):1:書寫一匿名塊,輸入兩個變量,分別為:2和4,計(jì)算兩個變量相乘,把相乘后的值附給另一個變量,同時打印出這個變量的值2:建立PL/SQL塊使用替代變量輸入兩個數(shù)字值,第一個數(shù)除以第二個數(shù),并加上第二個數(shù)產(chǎn)生最終結(jié)果,然后執(zhí)行該P(yáng)L/SQL塊,如下所示:Please enter the first number: 2Please enter the second number: 4PL/SQL procedure successfully completed. V_RESULT - 4.518建立PL/SQL塊,使用替代變量輸入全年工資總額和獎金百分比(10表示10%),輸出實(shí)際工資總和,如下
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五版保健食品電商平臺數(shù)據(jù)分析與用戶畫像合同2篇
- 二零二五版電影后期特效制作贊助合同3篇
- 二零二五年度建筑節(jié)能玻璃檢測與綠色建筑認(rèn)證合同3篇
- 二零二五年技術(shù)服務(wù)合同服務(wù)內(nèi)容和技術(shù)要求2篇
- 二零二五版存量房買賣合同家庭定制版2篇
- 二零二五版智能公廁建設(shè)與運(yùn)營管理合同3篇
- 二零二五版體育用品促銷員賽事贊助合同3篇
- 二零二五版鐘點(diǎn)工家政服務(wù)合同-含家政員行為規(guī)范3篇
- 二零二五版國際汽車運(yùn)輸與品牌合作推廣合同3篇
- 二零二五版能源節(jié)約型產(chǎn)品采購合同規(guī)范范本2篇
- 讓學(xué)生看見你的愛
- 銷售禮盒營銷方案
- 領(lǐng)導(dǎo)溝通的藝術(shù)
- 發(fā)生用藥錯誤應(yīng)急預(yù)案
- 南潯至臨安公路(南潯至練市段)公路工程環(huán)境影響報(bào)告
- 綠色貸款培訓(xùn)課件
- 大學(xué)生預(yù)征對象登記表(樣表)
- 主管部門審核意見三篇
- 初中數(shù)學(xué)校本教材(完整版)
- 父母教育方式對幼兒社會性發(fā)展影響的研究
- 新課標(biāo)人教版數(shù)學(xué)三年級上冊第八單元《分?jǐn)?shù)的初步認(rèn)識》教材解讀
評論
0/150
提交評論