版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
ORACLE入門(mén)
-PL/SQL語(yǔ)言篇技術(shù)支持部
湯慶鋒福州磬基電子有限公司ORACLE入門(mén)
-PL/SQL語(yǔ)言本課程學(xué)習(xí)內(nèi)容PL/SQL簡(jiǎn)介PL/SQL數(shù)據(jù)類型(ORACLE的數(shù)據(jù)類型)ORACL內(nèi)置的SQL函數(shù)PL/SQL中使用SQLPL/SQL中游標(biāo)的使用動(dòng)態(tài)PL/SQLPL/SQL的異常處理本課程學(xué)習(xí)內(nèi)容PL/SQL簡(jiǎn)介PL/SQL簡(jiǎn)介
PL/SQL(ProceduralLanguage/SQL)即模塊化的程序設(shè)計(jì)語(yǔ)言,用于從各種環(huán)境中訪問(wèn)ORACLE數(shù)據(jù)庫(kù)。它具備了許多SQL中所沒(méi)有的過(guò)程化屬性方面的特點(diǎn)。主要包括:變量和類型控制結(jié)構(gòu)(條件語(yǔ)句、循環(huán)語(yǔ)句…)過(guò)程、函數(shù)游標(biāo)異常處理PL/SQL簡(jiǎn)介PL/SQL(ProceduralLPL/SQL程序的用途無(wú)名塊就是沒(méi)有命名的PL/SQL塊,它可以嵌入某一個(gè)應(yīng)用之中.存儲(chǔ)過(guò)程、函數(shù)也就是命名了的PL/SQL塊,它可以接收參數(shù),并且可以重復(fù)的被調(diào)用。觸發(fā)器是與數(shù)據(jù)庫(kù)中的表相關(guān)的PL/SQL塊,可以自動(dòng)的觸發(fā)。包命名了的PL/SQL塊,由一組相關(guān)的過(guò)程、函數(shù)和標(biāo)識(shí)符組成。PL/SQL程序的用途無(wú)名塊PL/SQL的程序結(jié)構(gòu)
PL/SQL的基本單位是“塊”(Block)。所有的PL/SQL程序都是由一個(gè)或多個(gè)PL/SQL塊構(gòu)成的,這些塊可以相互進(jìn)行嵌套。通常一個(gè)塊完成程序的一個(gè)單元的工作。一個(gè)基本的塊由三個(gè)部分組成:定義部分定義變量、常量、游標(biāo)、異常處理可執(zhí)行部分包括對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作的SQL語(yǔ)句,以及對(duì)塊中的語(yǔ)句進(jìn)行組織、控制的PL/SQL語(yǔ)句。異常處理(Exception)部分可執(zhí)行部分中的語(yǔ)句,在執(zhí)行過(guò)程中出錯(cuò)或出現(xiàn)非正常現(xiàn)象時(shí),所做的響應(yīng)處理DECLAREBEGINEXCEPTIONENDPL/SQL塊結(jié)構(gòu)PL/SQL的程序結(jié)構(gòu)PL/SQL的基本單位是“塊”P(pán)L/SQL數(shù)據(jù)類型PL/SQL數(shù)據(jù)類型PL/SQL數(shù)據(jù)類型常用的數(shù)據(jù)類型CHAR:存放固定長(zhǎng)度的字符串VARCHAR2:存放可變長(zhǎng)度的字符串NUMBER:存放0、正負(fù)數(shù)、浮點(diǎn)數(shù)DATE:存放時(shí)間數(shù)據(jù)(包括日期和時(shí)間)LONG:存放變長(zhǎng)字符串。一般用來(lái)存儲(chǔ)大文本RAWLONG存放多媒體數(shù)據(jù),如聲音、圖片例如:創(chuàng)建一雇員表CREATETABLEemp(empnonumber(4),enamevarchar2(10),hiredatedate,salnumber(7,2),deptnonumber(2));PL/SQL數(shù)據(jù)類型常用的數(shù)據(jù)類型ORACLE內(nèi)置的SQL函數(shù)
SQL函數(shù)按照傳入?yún)?shù)的類型,可分為字符串函數(shù)、數(shù)值函數(shù)、日期函數(shù)、其他函數(shù)。以下分別列舉較常用的部分進(jìn)行說(shuō)明。字符串函數(shù):UPPER(s)將字符串‘s’轉(zhuǎn)換成大寫(xiě)的形式返回。LOWER(s)將字符串‘s’轉(zhuǎn)換成小寫(xiě)的形式返回。SUBSTR(s,a[,b])返回從字符位置a開(kāi)始有b個(gè)字符長(zhǎng)的‘s’的一部分。若a為正數(shù):從左邊向右邊計(jì)算若a為負(fù)數(shù):從右邊向左邊計(jì)算實(shí)例:Selectsubstr(‘a(chǎn)bcdefg123’,4)fromdual;結(jié)果返回:‘defg123’Selectsubstr(‘a(chǎn)bcdefg123’,4,2)fromdual;結(jié)果返回:‘de’Selectsubstr(‘a(chǎn)bcdefg123’,-4,2)fromdual;結(jié)果返回:‘g1’RTRIM(s1,s2)返回刪除從最右邊算起出現(xiàn)在s2中的字符的s1。s2缺省為空格實(shí)例:Selectrtrim(‘a(chǎn)abbccdd’,’cd’)fromdual;結(jié)果返回:‘a(chǎn)abb’Selectrtrim(‘a(chǎn)abbccdd’,’dc’)fromdual;結(jié)果返回:‘a(chǎn)abb’ORACLE內(nèi)置的SQL函數(shù)SQL函數(shù)按照傳入?yún)?shù)的類ORACL內(nèi)置的SQL函數(shù)Concat(s1,s2)返回串接上s2之后的s1.該函數(shù)與||運(yùn)算符作用相同。實(shí)例:selectconcat(‘a(chǎn)bc’,’def’)fromdual;返回結(jié)果:‘a(chǎn)bcdef’select‘a(chǎn)bc’||’def’fromdual;返回結(jié)果:‘a(chǎn)bcdef’Length(s)以字節(jié)為單位返回字符串s的長(zhǎng)度。ORACL內(nèi)置的SQL函數(shù)Concat(s1,s2)ORACL內(nèi)置的SQL函數(shù)數(shù)值函數(shù)Ceil(n)返回大于或等于n的整數(shù)Selectceil(18.6),ceil(-18.6)fromdual;Floor(n)返回小于或等于n的整數(shù)Selectfloor(18.6),floor(-18.6)fromdual;Mod(x,y)返回x除以y得余數(shù),若y為0,則返回x。Selectmod(23,5),mod(4,1.3)fromdual;返回結(jié)果:1.1,0.1Round(x,[,y])返回舍入到小數(shù)點(diǎn)右邊y為的x值。Selectround(1.56),round(1.56,1),round(123.4,-1)fromdual;返回結(jié)果:1.1,0.1,120ORACL內(nèi)置的SQL函數(shù)數(shù)值函數(shù)ORACL內(nèi)置的SQL函數(shù)日期函數(shù)Sysdate返回當(dāng)前的日期和時(shí)間Add_months(D,x)Last_day(D)返回日期D的月份的最后一天的日期Months_Between(D1,D2)返回在D1和D2之間月的數(shù)目。Trunc(D[,format])返回結(jié)尾由format指定的單位的日期。示例:Selecttrunc(sysdate,’year’)fromdual;返回今年的第一天Selecttrunc(sysdate,’mm’)fromdual;返回本月的第一天Selecttrunc(sysdate,’D’)fromdual;返回本周的第一天ORACL內(nèi)置的SQL函數(shù)日期函數(shù)ORACL內(nèi)置的SQL函數(shù)轉(zhuǎn)換函數(shù)To_char(D,format)將日期轉(zhuǎn)換為指定格式的字符串。示例:Selectto_char(sysdate,’yyyy/mm/ddhh:mi:ss’)fromdual;To_Date(string,format)將字符串轉(zhuǎn)換成日期格式示例:Selectto_date(‘2000/10/01’,’yyyy/mm/dd’)fromdual;Last_day(D)返回日期D的月份的最后一天的日期To_Number(string[,format])ORACL內(nèi)置的SQL函數(shù)轉(zhuǎn)換函數(shù)ORACL內(nèi)置的SQL函數(shù)其它函數(shù)Nvl(a,b)空值替換函數(shù),若a為空,則替換成b。示例:Selectename,sal,sal+nvl(comm,0)fromdual;DECODE(條件,值1,翻譯值1,值2,翻譯值2,...值n,翻譯值n,缺省值)該函數(shù)的含義如下:
IF條件=值1THEN
RETURN(翻譯值1)
ELSIF條件=值2THEN
RETURN(翻譯值2)
......
ELSIF條件=值nTHEN
RETURN(翻譯值n)
ELSE
RETURN(缺省值)
ENDIF
ORACL內(nèi)置的SQL函數(shù)其它函數(shù)PL/SQL的注釋注釋增強(qiáng)了可閱讀性,使得程序更易于理解。單行注釋--comment多行注釋/*comment*/注意:此注釋不能作用在SQL語(yǔ)言上。示例:DECLAREv_deptnonumber(2);--與雇員表中部門(mén)代碼字段交互的變量v_salnumber(7,2);--與雇員表中工資字段交互的變量BEGIN/*thisisatest!*/selectdeptno,salintov_deptno,v_salfromempwhereempno=7788;END;PL/SQL的注釋注釋增強(qiáng)了可閱讀性,使得程序更易于理解PL/SQL塊的定義部分
在PL/SQL塊中引用的所有標(biāo)識(shí)符,都必須在定義部分中明確定義。定義常量格式:〈標(biāo)識(shí)符〉CONSTANT〈數(shù)據(jù)類型〉:=〈表達(dá)式〉]例:定義一常量PI,值為3.14。PICONSTANTNUMBER(3,2):=3.14;定義標(biāo)量型變量標(biāo)量型數(shù)據(jù)類型,是指數(shù)據(jù)類型為個(gè)體型。格式:<標(biāo)識(shí)符><數(shù)據(jù)類型>[NOTNULL][:=|DEFAULT<表達(dá)式>]例:定義一寬度為10個(gè)字符的字符串變量X。DECLAREXCHAR(5);yCHAR(5):=‘ORACLE’;ZCHAR(5)default‘oracle’;PL/SQL塊的定義部分在PL/SQL塊中引用的所有標(biāo)代表數(shù)據(jù)庫(kù)列的變量先看一個(gè)示例:創(chuàng)建一PL/SQL塊,根據(jù)部門(mén)號(hào),返回部門(mén)名稱.DECLAREv_dnamedept.dname%type;BEGINSELECTdnameINTOv_dnameFROMDEPTWHEREdeptno=10;DBMS_OUTPUT.PUT_LINE(v_dname));EXCEPTIONWHENNO_DATA_FOUNDTHENDBMS_OUTPUT.PUT_LINE(‘sorry:nodatafound!’);END;問(wèn)題:所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型不知道?所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型將來(lái)改變改變?cè)趺崔k?代表數(shù)據(jù)庫(kù)列的變量先看一個(gè)示例:創(chuàng)建一PL/SQL塊,根據(jù)部PL/SQL塊的定義部分另一種定義標(biāo)量型變量的方法——%TYPE
定義一個(gè)變量,其數(shù)據(jù)類型與已知變量的數(shù)據(jù)類型相同,或者與數(shù)據(jù)庫(kù)表的某個(gè)列的數(shù)據(jù)類型相同。%TYPE的優(yōu)點(diǎn)在于:所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型可以不必知道。所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型可以實(shí)時(shí)改變。格式:<標(biāo)識(shí)符><已知變量或表列>[NOTNULL][:=|DEFAULT<表達(dá)式>]<變量名><基表名>.<列名>%TYPE例:定義一個(gè)變量,其數(shù)據(jù)類型基于另一個(gè)變量DECLAREV_1NUMBER(7,2);V_11V1%TYPE:=12345.6;例:定義一個(gè)變量,其數(shù)據(jù)類型基于數(shù)據(jù)庫(kù)中表的列DECLAREv_enameEMP.ENAME%TYPE;V_SALEMP.SAL%TYPE;PL/SQL塊的定義部分另一種定義標(biāo)量型變量的方法——%TYPL/SQL塊的定義部分另一種定義組合型變量的方法——%ROWTYPE
定義一個(gè)變量,其數(shù)據(jù)類型與數(shù)據(jù)庫(kù)表的數(shù)據(jù)結(jié)構(gòu)相同。%ROWTYPE的優(yōu)點(diǎn)在于:所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型可以不必知道。所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型可以實(shí)時(shí)改變。簡(jiǎn)易格式:<變量名><基表名>%ROWTYPE例:DECLAREv_empemp%rowtype;BEGINSELECT*INTOv_empFROMempWHEREempno=7788;DBMS_OUTPUT.PUT_LINE(v_emp.empno);DBMS_OUTPUT.PUT_LINE(v_emp.ename);DBMS_OUTPUT.PUT_LINE(v_emp.job);DBMS_OUTPUT.PUT_LINE(v_emp.sal);END;PL/SQL塊的定義部分另一種定義組合型變量的方法——%RO變量的引用和賦值標(biāo)量變量賦值格式:<變量>:=<表達(dá)式>;例:V_NAME:=‘JOAN’;v_demptno:=10;組合型變量賦值格式:〈變量.域名〉〈(主鍵值)〉:=〈表達(dá)式〉;例:v_emp.sal:=8888;v_m:=8888;變量的引用和賦值標(biāo)量變量賦值PL/SQL中使用SQL在PL/SQL塊中,通過(guò)SQL語(yǔ)句對(duì)ORACLE數(shù)據(jù)庫(kù)中的數(shù)據(jù)進(jìn)行存取。在PL/SQL中:可以使用的SQL語(yǔ)句有:SELECT、INSERT、DELETE、UPDATE、COMMIT、ROLLBACK不可以直接使用的SQL語(yǔ)句有:數(shù)據(jù)定義語(yǔ)句(DDL),如:CREATETALBE,DROPTABLE數(shù)據(jù)控制語(yǔ)句(DCL),如:GRANT、REVOKE備注:在PL/SQL2.1以上版本,允許通過(guò)DBMS_SQL包來(lái)創(chuàng)建動(dòng)態(tài)SQL語(yǔ)句。PL/SQL中使用SQL在PL/SQL塊中,通過(guò)SQLPL/SQL中使用SQL-SELECT語(yǔ)句SELECT語(yǔ)句:將數(shù)據(jù)從數(shù)據(jù)庫(kù)中檢索出來(lái)并放入PL/SQL變量中。格式:SELECT<表列>INTO<變量>FROM<表>例:查詢某個(gè)雇員的姓名及工資。DECLAREv_empnoemp.empno%type:=7788;v_enameemp.ename%type;v_salemp.sal%type;BEGINselectename,salintov_ename,v_salfromempwhereempno=v_empno;DBMS_OUTPUT.PUT_LINE(v_empno||v_ename||v_sal);EXCEPTIONWHENNO_DATA_FOUNDTHENDBMS_OUTPUT.PUT_LINE(‘sorry:nodatafound!’);END;/PL/SQL中的SELECT語(yǔ)句中必須包含INTO子句,而且對(duì)應(yīng)的個(gè)數(shù)要相同,位置要一一對(duì)應(yīng)。查詢結(jié)果只返回一條記錄,否則會(huì)產(chǎn)生異常情況。(1)查詢結(jié)果多于一條記錄異常變量:TOO_MANY_ROWS(2)查詢結(jié)果沒(méi)有返回記錄異常變量:NO_DATA_FOUNDPL/SQL中使用SQL-SELECT語(yǔ)句SELECT語(yǔ)句:PL/SQL中使用SQL在PL/SQL中,對(duì)數(shù)據(jù)庫(kù)進(jìn)行插入(INSERT)、刪除(DELETE)、修改(UPDATE)語(yǔ)句,其語(yǔ)法形式與SQL中的是完全一樣的。例:在EMP表中刪去某個(gè)雇員。BEGINDELETEempWHEREempno=7788;COMMIT;END;PL/SQL中使用SQL在PL/SQL中,對(duì)數(shù)據(jù)庫(kù)進(jìn)PL/SQL的執(zhí)行部分——流程控制語(yǔ)句流程控制語(yǔ)句主要有三種:條件控制循環(huán)控制跳轉(zhuǎn)控制PL/SQL的執(zhí)行部分——流程控制語(yǔ)句流程控制語(yǔ)句主要有三種流程控制語(yǔ)句——條件控制語(yǔ)法格式:IF〈條件〉THEN〈語(yǔ)句〉;[ELSIF〈條件〉THEN〈語(yǔ)句〉;][ELSE〈語(yǔ)句〉;]ENDIF;例:根據(jù)職務(wù)浮動(dòng)工資IFv_job=‘MANAGER’THENv_sal:=v_sal*1.3;ELSIFv_job=‘SALESMAN’THENv_sal:=v_sal*1.2;ELSEv_sal:=v_sal*1.1;ENDIF;updateempsetsal=v_salwhereempno=1234;流程控制語(yǔ)句——條件控制語(yǔ)法格式:例:根據(jù)職務(wù)浮動(dòng)工資流程控制語(yǔ)句——循環(huán)控制在PL/SQL中循環(huán)控制的有以下四種:簡(jiǎn)單循環(huán)FOR循環(huán)WHERE循環(huán)用于游標(biāo)的FOR循環(huán)流程控制語(yǔ)句——循環(huán)控制在PL/SQL中循環(huán)控制的有以下四種循環(huán)控制——簡(jiǎn)單循環(huán)語(yǔ)法格式:LOOP〈語(yǔ)句1〉;〈語(yǔ)句2〉;…EXITWHEN〈條件〉;ENDLOOP;例:把數(shù)值1到50順序插入表中。V_counter:=1;LOOPINSERTINTOtemp_tableVALUES(v_counter);EXITWHENv_counter>50;V_count:=v_count+1;ENDLOOP;循環(huán)控制——簡(jiǎn)單循環(huán)語(yǔ)法格式:例:把數(shù)值1到50順序插入表中循環(huán)控制——FOR循環(huán)語(yǔ)法格式:FOR〈循環(huán)變量〉IN[REVERSE]〈下界〉..〈上界〉LOOP〈語(yǔ)句1〉;〈語(yǔ)句2〉;…ENDLOOP;REVERSE:使計(jì)數(shù)器由上界到下界遞減計(jì)數(shù)例:把數(shù)值1到50順序插入表中。FORv_counterIN1..50LOOPINSERTINTOtemp_tableVALUES(v_counter);ENDLOOP;循環(huán)控制——FOR循環(huán)語(yǔ)法格式:例:把數(shù)值1到50順序插入表循環(huán)控制——WHILE循環(huán)語(yǔ)法格式:WHILE〈條件〉LOOP〈語(yǔ)句1〉;〈語(yǔ)句2〉;…ENDLOOP;例:把數(shù)值1到50順序插入表中。V_counter:=1;WHILEv_counter<=50LOOPINSERTINTOtemp_tableVALUES(v_counter);V_count:=v_count+1;ENDLOOP;循環(huán)控制——WHILE循環(huán)語(yǔ)法格式:例:把數(shù)值1到50順序插跳轉(zhuǎn)控制語(yǔ)句語(yǔ)法格式:<<標(biāo)號(hào)>>……GOTO<<標(biāo)號(hào)>>;
在進(jìn)行PL/SQL編程時(shí),盡量避免或不用GOTO語(yǔ)句,因?yàn)檫@種無(wú)條件的跳轉(zhuǎn)語(yǔ)句打破了程序的邏輯性,有悖于自頂向下的編程風(fēng)格.跳轉(zhuǎn)控制語(yǔ)句語(yǔ)法格式:PL/SQL游標(biāo)的使用游標(biāo)(CURSOR)的功能,是ORALCE系統(tǒng)為了將所有查詢結(jié)果返回給用戶程序而提供的。一個(gè)游標(biāo),實(shí)際上是在內(nèi)存中開(kāi)辟一個(gè)工作區(qū),它對(duì)應(yīng)一條SELECT語(yǔ)句。當(dāng)打開(kāi)游標(biāo)時(shí),就是執(zhí)行游標(biāo)所對(duì)應(yīng)的SELECT語(yǔ)句,并將其查詢結(jié)果放入工作區(qū),并且指針指向工作區(qū)的首部。通過(guò)光標(biāo)上的操作可以把這些記錄檢索到客戶端的應(yīng)用程序。CURSOR內(nèi)存區(qū)POINTERSELECT…INTO…:只能查詢數(shù)據(jù)庫(kù)的單條記錄,并把記錄的數(shù)據(jù)賦給變量。PL/SQL游標(biāo)的使用游標(biāo)(CURSOR)的功能,是ORAL游標(biāo)——定義和操縱游標(biāo)步驟:定義游標(biāo)打開(kāi)游標(biāo)從游標(biāo)中取值關(guān)閉游標(biāo)游標(biāo)——定義和操縱游標(biāo)步驟:定義游標(biāo)定義游標(biāo),就是定義一個(gè)游標(biāo)名,以及與其相對(duì)應(yīng)的SELECT語(yǔ)句。語(yǔ)法格式:CURSOR〈游標(biāo)名〉IS〈SELECT子句〉;示例:定義一個(gè)包含所有雇員記錄的游標(biāo)。cursorcur_empisselect*fromemp;定義游標(biāo)打開(kāi)游標(biāo)打開(kāi)游標(biāo),就是執(zhí)行游標(biāo)所對(duì)應(yīng)的SELECT語(yǔ)句,將其查詢結(jié)果放入工作區(qū),并且指針指向工作區(qū)的首部。語(yǔ)法格式:OPEN〈游標(biāo)名〉;打開(kāi)游標(biāo)從游標(biāo)中取值取值工作是將游標(biāo)工作區(qū)中的數(shù)據(jù)取出一行,放入指定的輸出變量中。語(yǔ)法格式:FETCH〈游標(biāo)名〉INTO〈變量1〉,〈變量2〉…;示例:fetchcur_empintov_empno,v_ename,v_sal,v_comm,v_deptno關(guān)閉游標(biāo)釋放與該游標(biāo)相關(guān)的資源。語(yǔ)法格式:CLOSE<游標(biāo)名>;示例:closecur_emp;從游標(biāo)中取值游標(biāo)的屬性從游標(biāo)工作區(qū)中逐一地取數(shù)據(jù),可以在循環(huán)中完成。但循環(huán)的開(kāi)始以及結(jié)束,需以游標(biāo)屬性為依據(jù)。游標(biāo)屬性有:%ISOPEN:判斷游標(biāo)是否被打開(kāi)%NOTFOUND:判斷何時(shí)中斷循環(huán)%FOUND:與%NOTFOUND相反%ROWCOUNT:實(shí)際從游標(biāo)工作區(qū)抽取的記錄數(shù)示例:Opencur_emp;Loopfetchcur_empintov_empno,v_ename,v_sal,v_deptno;exitwhencur_emp%NOTFOUND;Endloop;游標(biāo)的屬性從游標(biāo)工作區(qū)中逐一地取數(shù)據(jù),可以在循環(huán)中完成游標(biāo)——用于游標(biāo)的FOR循環(huán)游標(biāo)的FOR循環(huán),是一種簡(jiǎn)單的游標(biāo)操作方法,系統(tǒng)隱式地進(jìn)行游標(biāo)的打開(kāi)、提取數(shù)據(jù)、循環(huán)、關(guān)閉。格式:
FOR〈記錄變量〉IN〈游標(biāo)名〉LOOP〈語(yǔ)句…>;
ENDLOOP;<記錄變量>:由系統(tǒng)隱含定義的記錄名示例:Declarecursorcur_empisselect*fromemp;Beginforv_empincur_emploop
DBMS_OUTPUT.PUT_LINE(v_emp.ename);
DBMS_OUTPUT.PUT_LINE(v_emp.sal);endloop;End;游標(biāo)——用于游標(biāo)的FOR循環(huán)游標(biāo)的FOR循環(huán),是一種簡(jiǎn)一個(gè)完整的示例例:建立一存儲(chǔ)過(guò)程,根據(jù)職務(wù)修改工資CREATEORREPLACEPROCEDUREp_update_salASCURSORcur_empISSELECT*FROMemp;v_empcur_emp%ROWTYPE;BEGINOPENcur_emp;LOOPFETCHcur_empINTOv_emp;EXITWHENcur_emp%NOTFOUND;IFv_emp.job=‘MANAGER’THENv_emp.sal:=v_emp.sal*1.3;ELSIFv_emp.job=‘SALESMAN’THENv_emp.sal:=v_emp.sal*1.2;ELSEv_emp.sal:=v_emp.sal*1.1;ENDIF;UPDATEempSETsal=v_emp.salWHEREempno=v_emp.empno;ENDLOOP;CLOSEcur_emp;COMMIT;END;一個(gè)完整的示例例:建立一存儲(chǔ)過(guò)程,根據(jù)職務(wù)修改工資ELSIF一個(gè)完整的示例(用FOR循環(huán))CREATEPROCEDUREp_update_salASCURSORcur_empISSELECT*FROMemp;BEGINFORv_empINcur_empLOOPIFv_emp.job=‘MANAGER’THENv_emp.sal:=v_emp.sal*1.3;ELSIFv_emp.job=‘SALESMAN’THENv_emp.sal:=v_emp.sal*1.2;ELSEv_sal:=v_sal*1.1;ENDIF;UPDATEempSETsal=v_emp.salWHEREempno=v_emp.empno;ENDLOOP;COMMIT;END;一個(gè)完整的示例(用FOR循環(huán))CREATEPROCEDUR示例DECLARECURSORc1isSELECTename,empno,salFROMempORDERBYsalDESC;--startwithhighestpaidemployeemy_enameCHAR(10);my_empnoNUMBER(4);my_salNUMBER(7,2);BEGINOPENc1;FORiIN1..5LOOPFETCHc1INTOmy_ename,my_empno,my_sal;EXITWHENc1%NOTFOUND;INSERTINTOtempVALUES(my_sal,my_empno,my_ename);COMMIT;ENDLOOP;CLOSEc1;END;示例DECLARE異常處理
PL/SQL中,將程序執(zhí)行過(guò)程中的一個(gè)警告或錯(cuò)誤稱為一個(gè)異常(EXCEPTION)。異常情況的種類有三種:預(yù)定義的ORACLE錯(cuò)誤ORACLE預(yù)定一的異常情況大約有24個(gè)。對(duì)這種異常情況的處理,無(wú)須在程序中定義,由ORACLE自動(dòng)將其引發(fā)。非預(yù)定義的ORACLE錯(cuò)誤即其他標(biāo)準(zhǔn)的ORACLE錯(cuò)誤。對(duì)這種異常情況的處理,需在定義部分定義,然后由ORACLE自動(dòng)將其引發(fā)。用戶定義的錯(cuò)誤程序執(zhí)行過(guò)程中,出現(xiàn)編程人員認(rèn)為非正常的。對(duì)這種異常情況的處理,需在定義部分定義,然后顯式由地將其引發(fā)。異常處理PL/SQL中,將程序執(zhí)行過(guò)程中的一個(gè)警告或錯(cuò)異常處理語(yǔ)法格式:EXCEPTIONWHEN<異常情況1>THEN〈語(yǔ)句〉;[WHEN<異常情況2〉THEN〈語(yǔ)句〉;…[WHENOTHERSTHEN〈語(yǔ)句〉;]OTHERS:指沒(méi)有列在異常處理部分中的其他異常情況。DECLAREBEGINEXCEPTIONENDPL/SQL塊執(zhí)行過(guò)程異常發(fā)生異常處理異常處理語(yǔ)法格式:DECLAREBEGINEXCEPTION異常處理預(yù)定義的ORACLE錯(cuò)誤預(yù)定義的異常名稱錯(cuò)誤號(hào)說(shuō)明CURSOR_ALREADY_OPENORA-6511試圖打開(kāi)一個(gè)已打開(kāi)的光標(biāo)LOGIN_DENIEDORA-1017無(wú)效的用戶名或者口令NO_DATA_FOUNDORA-1403查詢未找到數(shù)據(jù)NOT_LOGGED_ONORA-1012還未連接就試圖數(shù)據(jù)庫(kù)操作DUP_VAL_ON_INDEXORA-0001試圖破壞一個(gè)唯一性限制TIMEOUT_ON_RESOURCEORA-0051發(fā)生超時(shí)TRANSACTION_BACKED_OUTORA-006由于死鎖提交被退回TOO_MANY_ROWSORA-1422SELECTINTD命令返回的多行異常處理預(yù)定義的ORACLE錯(cuò)誤預(yù)定義的異常名稱錯(cuò)誤號(hào)說(shuō)明C異常處理預(yù)定義異常示例:BEGINinsertintoemp(empno,ename)values(7788,'testuser');EXCEPTIONWHENDUP_VAL_ON_INDEXTHENDBMS_OUTPUT.PUT_LINE('錯(cuò)誤:破壞了唯一性的原則!');
WHENOTHERSTHENDBMS_OUTPUT.PUT_LINE('錯(cuò)誤:未知!');END;對(duì)預(yù)定義異常情況的處理,無(wú)須在程序中定義,由ORACLE自動(dòng)將其引發(fā)。異常處理預(yù)定義異常示例:異常處理非預(yù)定義的ORACLE異常處理
對(duì)于這類的異常情況的處理,首先必須對(duì)非預(yù)定義的ORACLE錯(cuò)誤進(jìn)行定義。其處理步驟為:在PL/SQL塊的定義部分定義異常情況語(yǔ)法:<異常情況名>EXCEPTION;將定義好的異常情況,與標(biāo)準(zhǔn)的ORACLE錯(cuò)誤聯(lián)系起來(lái),使用EXCEPTION_INIT語(yǔ)句。語(yǔ)法:PRAGMAEXCEPTION_INIT(<異常情況>,<錯(cuò)誤代碼>);在PL/SQL塊的異常情況處理部分作出相應(yīng)的處理。示例:DECLAREe_missNUllexception;PRAGMAEXCEPTION_INIT(e_missNull,-1400);BEGINinsertintoemp(ename)valus(‘TOM’);EXCEPTIONwhene_missNullthenDBMS_OUTPUT.PUT_LINE(‘錯(cuò)誤:雇員代碼不能為空!’);
END;
異常處理非預(yù)定義的ORACLE異常處理異常處理用戶自定義的異常處理對(duì)于用戶自定義的異常情況的處理,一般都需要用戶在PL/SQL塊中進(jìn)行定義,然后顯示地將其引發(fā)。步驟為:在PL/SQL塊的定義部分定義異常情況名在PL/SQL塊的可執(zhí)行部分將其引發(fā),使用RAISE語(yǔ)句。語(yǔ)法為:RAISE<異常情況>;示例:DECLAREDEPT_CODENUMBER(2);INVALID_DEPT_CODEEXCEPTION;BEGINDEPT_CODE=X;IFDEPT_CODENOTIN(10,20,30,40)THENRAISEINVALID_DEPT_CODE;ENDIF;EXCEPTIONWHENINVALID_DEPT_CODETHENDBMS_OUTPUT.PUT_LINE('INVALIDDepartmentCODE');END;異常不一定必須是oracle返回的系統(tǒng)錯(cuò)誤,用戶可以在自己的應(yīng)用程序中創(chuàng)建可觸發(fā)及可處理的自定義異常。異常處理用戶自定義的異常處理問(wèn)題?問(wèn)題?ORACLE入門(mén)
-PL/SQL語(yǔ)言篇技術(shù)支持部
湯慶鋒福州磬基電子有限公司ORACLE入門(mén)
-PL/SQL語(yǔ)言本課程學(xué)習(xí)內(nèi)容PL/SQL簡(jiǎn)介PL/SQL數(shù)據(jù)類型(ORACLE的數(shù)據(jù)類型)ORACL內(nèi)置的SQL函數(shù)PL/SQL中使用SQLPL/SQL中游標(biāo)的使用動(dòng)態(tài)PL/SQLPL/SQL的異常處理本課程學(xué)習(xí)內(nèi)容PL/SQL簡(jiǎn)介PL/SQL簡(jiǎn)介
PL/SQL(ProceduralLanguage/SQL)即模塊化的程序設(shè)計(jì)語(yǔ)言,用于從各種環(huán)境中訪問(wèn)ORACLE數(shù)據(jù)庫(kù)。它具備了許多SQL中所沒(méi)有的過(guò)程化屬性方面的特點(diǎn)。主要包括:變量和類型控制結(jié)構(gòu)(條件語(yǔ)句、循環(huán)語(yǔ)句…)過(guò)程、函數(shù)游標(biāo)異常處理PL/SQL簡(jiǎn)介PL/SQL(ProceduralLPL/SQL程序的用途無(wú)名塊就是沒(méi)有命名的PL/SQL塊,它可以嵌入某一個(gè)應(yīng)用之中.存儲(chǔ)過(guò)程、函數(shù)也就是命名了的PL/SQL塊,它可以接收參數(shù),并且可以重復(fù)的被調(diào)用。觸發(fā)器是與數(shù)據(jù)庫(kù)中的表相關(guān)的PL/SQL塊,可以自動(dòng)的觸發(fā)。包命名了的PL/SQL塊,由一組相關(guān)的過(guò)程、函數(shù)和標(biāo)識(shí)符組成。PL/SQL程序的用途無(wú)名塊PL/SQL的程序結(jié)構(gòu)
PL/SQL的基本單位是“塊”(Block)。所有的PL/SQL程序都是由一個(gè)或多個(gè)PL/SQL塊構(gòu)成的,這些塊可以相互進(jìn)行嵌套。通常一個(gè)塊完成程序的一個(gè)單元的工作。一個(gè)基本的塊由三個(gè)部分組成:定義部分定義變量、常量、游標(biāo)、異常處理可執(zhí)行部分包括對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作的SQL語(yǔ)句,以及對(duì)塊中的語(yǔ)句進(jìn)行組織、控制的PL/SQL語(yǔ)句。異常處理(Exception)部分可執(zhí)行部分中的語(yǔ)句,在執(zhí)行過(guò)程中出錯(cuò)或出現(xiàn)非正常現(xiàn)象時(shí),所做的響應(yīng)處理DECLAREBEGINEXCEPTIONENDPL/SQL塊結(jié)構(gòu)PL/SQL的程序結(jié)構(gòu)PL/SQL的基本單位是“塊”P(pán)L/SQL數(shù)據(jù)類型PL/SQL數(shù)據(jù)類型PL/SQL數(shù)據(jù)類型常用的數(shù)據(jù)類型CHAR:存放固定長(zhǎng)度的字符串VARCHAR2:存放可變長(zhǎng)度的字符串NUMBER:存放0、正負(fù)數(shù)、浮點(diǎn)數(shù)DATE:存放時(shí)間數(shù)據(jù)(包括日期和時(shí)間)LONG:存放變長(zhǎng)字符串。一般用來(lái)存儲(chǔ)大文本RAWLONG存放多媒體數(shù)據(jù),如聲音、圖片例如:創(chuàng)建一雇員表CREATETABLEemp(empnonumber(4),enamevarchar2(10),hiredatedate,salnumber(7,2),deptnonumber(2));PL/SQL數(shù)據(jù)類型常用的數(shù)據(jù)類型ORACLE內(nèi)置的SQL函數(shù)
SQL函數(shù)按照傳入?yún)?shù)的類型,可分為字符串函數(shù)、數(shù)值函數(shù)、日期函數(shù)、其他函數(shù)。以下分別列舉較常用的部分進(jìn)行說(shuō)明。字符串函數(shù):UPPER(s)將字符串‘s’轉(zhuǎn)換成大寫(xiě)的形式返回。LOWER(s)將字符串‘s’轉(zhuǎn)換成小寫(xiě)的形式返回。SUBSTR(s,a[,b])返回從字符位置a開(kāi)始有b個(gè)字符長(zhǎng)的‘s’的一部分。若a為正數(shù):從左邊向右邊計(jì)算若a為負(fù)數(shù):從右邊向左邊計(jì)算實(shí)例:Selectsubstr(‘a(chǎn)bcdefg123’,4)fromdual;結(jié)果返回:‘defg123’Selectsubstr(‘a(chǎn)bcdefg123’,4,2)fromdual;結(jié)果返回:‘de’Selectsubstr(‘a(chǎn)bcdefg123’,-4,2)fromdual;結(jié)果返回:‘g1’RTRIM(s1,s2)返回刪除從最右邊算起出現(xiàn)在s2中的字符的s1。s2缺省為空格實(shí)例:Selectrtrim(‘a(chǎn)abbccdd’,’cd’)fromdual;結(jié)果返回:‘a(chǎn)abb’Selectrtrim(‘a(chǎn)abbccdd’,’dc’)fromdual;結(jié)果返回:‘a(chǎn)abb’ORACLE內(nèi)置的SQL函數(shù)SQL函數(shù)按照傳入?yún)?shù)的類ORACL內(nèi)置的SQL函數(shù)Concat(s1,s2)返回串接上s2之后的s1.該函數(shù)與||運(yùn)算符作用相同。實(shí)例:selectconcat(‘a(chǎn)bc’,’def’)fromdual;返回結(jié)果:‘a(chǎn)bcdef’select‘a(chǎn)bc’||’def’fromdual;返回結(jié)果:‘a(chǎn)bcdef’Length(s)以字節(jié)為單位返回字符串s的長(zhǎng)度。ORACL內(nèi)置的SQL函數(shù)Concat(s1,s2)ORACL內(nèi)置的SQL函數(shù)數(shù)值函數(shù)Ceil(n)返回大于或等于n的整數(shù)Selectceil(18.6),ceil(-18.6)fromdual;Floor(n)返回小于或等于n的整數(shù)Selectfloor(18.6),floor(-18.6)fromdual;Mod(x,y)返回x除以y得余數(shù),若y為0,則返回x。Selectmod(23,5),mod(4,1.3)fromdual;返回結(jié)果:1.1,0.1Round(x,[,y])返回舍入到小數(shù)點(diǎn)右邊y為的x值。Selectround(1.56),round(1.56,1),round(123.4,-1)fromdual;返回結(jié)果:1.1,0.1,120ORACL內(nèi)置的SQL函數(shù)數(shù)值函數(shù)ORACL內(nèi)置的SQL函數(shù)日期函數(shù)Sysdate返回當(dāng)前的日期和時(shí)間Add_months(D,x)Last_day(D)返回日期D的月份的最后一天的日期Months_Between(D1,D2)返回在D1和D2之間月的數(shù)目。Trunc(D[,format])返回結(jié)尾由format指定的單位的日期。示例:Selecttrunc(sysdate,’year’)fromdual;返回今年的第一天Selecttrunc(sysdate,’mm’)fromdual;返回本月的第一天Selecttrunc(sysdate,’D’)fromdual;返回本周的第一天ORACL內(nèi)置的SQL函數(shù)日期函數(shù)ORACL內(nèi)置的SQL函數(shù)轉(zhuǎn)換函數(shù)To_char(D,format)將日期轉(zhuǎn)換為指定格式的字符串。示例:Selectto_char(sysdate,’yyyy/mm/ddhh:mi:ss’)fromdual;To_Date(string,format)將字符串轉(zhuǎn)換成日期格式示例:Selectto_date(‘2000/10/01’,’yyyy/mm/dd’)fromdual;Last_day(D)返回日期D的月份的最后一天的日期To_Number(string[,format])ORACL內(nèi)置的SQL函數(shù)轉(zhuǎn)換函數(shù)ORACL內(nèi)置的SQL函數(shù)其它函數(shù)Nvl(a,b)空值替換函數(shù),若a為空,則替換成b。示例:Selectename,sal,sal+nvl(comm,0)fromdual;DECODE(條件,值1,翻譯值1,值2,翻譯值2,...值n,翻譯值n,缺省值)該函數(shù)的含義如下:
IF條件=值1THEN
RETURN(翻譯值1)
ELSIF條件=值2THEN
RETURN(翻譯值2)
......
ELSIF條件=值nTHEN
RETURN(翻譯值n)
ELSE
RETURN(缺省值)
ENDIF
ORACL內(nèi)置的SQL函數(shù)其它函數(shù)PL/SQL的注釋注釋增強(qiáng)了可閱讀性,使得程序更易于理解。單行注釋--comment多行注釋/*comment*/注意:此注釋不能作用在SQL語(yǔ)言上。示例:DECLAREv_deptnonumber(2);--與雇員表中部門(mén)代碼字段交互的變量v_salnumber(7,2);--與雇員表中工資字段交互的變量BEGIN/*thisisatest!*/selectdeptno,salintov_deptno,v_salfromempwhereempno=7788;END;PL/SQL的注釋注釋增強(qiáng)了可閱讀性,使得程序更易于理解PL/SQL塊的定義部分
在PL/SQL塊中引用的所有標(biāo)識(shí)符,都必須在定義部分中明確定義。定義常量格式:〈標(biāo)識(shí)符〉CONSTANT〈數(shù)據(jù)類型〉:=〈表達(dá)式〉]例:定義一常量PI,值為3.14。PICONSTANTNUMBER(3,2):=3.14;定義標(biāo)量型變量標(biāo)量型數(shù)據(jù)類型,是指數(shù)據(jù)類型為個(gè)體型。格式:<標(biāo)識(shí)符><數(shù)據(jù)類型>[NOTNULL][:=|DEFAULT<表達(dá)式>]例:定義一寬度為10個(gè)字符的字符串變量X。DECLAREXCHAR(5);yCHAR(5):=‘ORACLE’;ZCHAR(5)default‘oracle’;PL/SQL塊的定義部分在PL/SQL塊中引用的所有標(biāo)代表數(shù)據(jù)庫(kù)列的變量先看一個(gè)示例:創(chuàng)建一PL/SQL塊,根據(jù)部門(mén)號(hào),返回部門(mén)名稱.DECLAREv_dnamedept.dname%type;BEGINSELECTdnameINTOv_dnameFROMDEPTWHEREdeptno=10;DBMS_OUTPUT.PUT_LINE(v_dname));EXCEPTIONWHENNO_DATA_FOUNDTHENDBMS_OUTPUT.PUT_LINE(‘sorry:nodatafound!’);END;問(wèn)題:所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型不知道?所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型將來(lái)改變改變?cè)趺崔k?代表數(shù)據(jù)庫(kù)列的變量先看一個(gè)示例:創(chuàng)建一PL/SQL塊,根據(jù)部PL/SQL塊的定義部分另一種定義標(biāo)量型變量的方法——%TYPE
定義一個(gè)變量,其數(shù)據(jù)類型與已知變量的數(shù)據(jù)類型相同,或者與數(shù)據(jù)庫(kù)表的某個(gè)列的數(shù)據(jù)類型相同。%TYPE的優(yōu)點(diǎn)在于:所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型可以不必知道。所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型可以實(shí)時(shí)改變。格式:<標(biāo)識(shí)符><已知變量或表列>[NOTNULL][:=|DEFAULT<表達(dá)式>]<變量名><基表名>.<列名>%TYPE例:定義一個(gè)變量,其數(shù)據(jù)類型基于另一個(gè)變量DECLAREV_1NUMBER(7,2);V_11V1%TYPE:=12345.6;例:定義一個(gè)變量,其數(shù)據(jù)類型基于數(shù)據(jù)庫(kù)中表的列DECLAREv_enameEMP.ENAME%TYPE;V_SALEMP.SAL%TYPE;PL/SQL塊的定義部分另一種定義標(biāo)量型變量的方法——%TYPL/SQL塊的定義部分另一種定義組合型變量的方法——%ROWTYPE
定義一個(gè)變量,其數(shù)據(jù)類型與數(shù)據(jù)庫(kù)表的數(shù)據(jù)結(jié)構(gòu)相同。%ROWTYPE的優(yōu)點(diǎn)在于:所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型可以不必知道。所引用的數(shù)據(jù)庫(kù)表中的數(shù)據(jù)類型可以實(shí)時(shí)改變。簡(jiǎn)易格式:<變量名><基表名>%ROWTYPE例:DECLAREv_empemp%rowtype;BEGINSELECT*INTOv_empFROMempWHEREempno=7788;DBMS_OUTPUT.PUT_LINE(v_emp.empno);DBMS_OUTPUT.PUT_LINE(v_emp.ename);DBMS_OUTPUT.PUT_LINE(v_emp.job);DBMS_OUTPUT.PUT_LINE(v_emp.sal);END;PL/SQL塊的定義部分另一種定義組合型變量的方法——%RO變量的引用和賦值標(biāo)量變量賦值格式:<變量>:=<表達(dá)式>;例:V_NAME:=‘JOAN’;v_demptno:=10;組合型變量賦值格式:〈變量.域名〉〈(主鍵值)〉:=〈表達(dá)式〉;例:v_emp.sal:=8888;v_m:=8888;變量的引用和賦值標(biāo)量變量賦值PL/SQL中使用SQL在PL/SQL塊中,通過(guò)SQL語(yǔ)句對(duì)ORACLE數(shù)據(jù)庫(kù)中的數(shù)據(jù)進(jìn)行存取。在PL/SQL中:可以使用的SQL語(yǔ)句有:SELECT、INSERT、DELETE、UPDATE、COMMIT、ROLLBACK不可以直接使用的SQL語(yǔ)句有:數(shù)據(jù)定義語(yǔ)句(DDL),如:CREATETALBE,DROPTABLE數(shù)據(jù)控制語(yǔ)句(DCL),如:GRANT、REVOKE備注:在PL/SQL2.1以上版本,允許通過(guò)DBMS_SQL包來(lái)創(chuàng)建動(dòng)態(tài)SQL語(yǔ)句。PL/SQL中使用SQL在PL/SQL塊中,通過(guò)SQLPL/SQL中使用SQL-SELECT語(yǔ)句SELECT語(yǔ)句:將數(shù)據(jù)從數(shù)據(jù)庫(kù)中檢索出來(lái)并放入PL/SQL變量中。格式:SELECT<表列>INTO<變量>FROM<表>例:查詢某個(gè)雇員的姓名及工資。DECLAREv_empnoemp.empno%type:=7788;v_enameemp.ename%type;v_salemp.sal%type;BEGINselectename,salintov_ename,v_salfromempwhereempno=v_empno;DBMS_OUTPUT.PUT_LINE(v_empno||v_ename||v_sal);EXCEPTIONWHENNO_DATA_FOUNDTHENDBMS_OUTPUT.PUT_LINE(‘sorry:nodatafound!’);END;/PL/SQL中的SELECT語(yǔ)句中必須包含INTO子句,而且對(duì)應(yīng)的個(gè)數(shù)要相同,位置要一一對(duì)應(yīng)。查詢結(jié)果只返回一條記錄,否則會(huì)產(chǎn)生異常情況。(1)查詢結(jié)果多于一條記錄異常變量:TOO_MANY_ROWS(2)查詢結(jié)果沒(méi)有返回記錄異常變量:NO_DATA_FOUNDPL/SQL中使用SQL-SELECT語(yǔ)句SELECT語(yǔ)句:PL/SQL中使用SQL在PL/SQL中,對(duì)數(shù)據(jù)庫(kù)進(jìn)行插入(INSERT)、刪除(DELETE)、修改(UPDATE)語(yǔ)句,其語(yǔ)法形式與SQL中的是完全一樣的。例:在EMP表中刪去某個(gè)雇員。BEGINDELETEempWHEREempno=7788;COMMIT;END;PL/SQL中使用SQL在PL/SQL中,對(duì)數(shù)據(jù)庫(kù)進(jìn)PL/SQL的執(zhí)行部分——流程控制語(yǔ)句流程控制語(yǔ)句主要有三種:條件控制循環(huán)控制跳轉(zhuǎn)控制PL/SQL的執(zhí)行部分——流程控制語(yǔ)句流程控制語(yǔ)句主要有三種流程控制語(yǔ)句——條件控制語(yǔ)法格式:IF〈條件〉THEN〈語(yǔ)句〉;[ELSIF〈條件〉THEN〈語(yǔ)句〉;][ELSE〈語(yǔ)句〉;]ENDIF;例:根據(jù)職務(wù)浮動(dòng)工資IFv_job=‘MANAGER’THENv_sal:=v_sal*1.3;ELSIFv_job=‘SALESMAN’THENv_sal:=v_sal*1.2;ELSEv_sal:=v_sal*1.1;ENDIF;updateempsetsal=v_salwhereempno=1234;流程控制語(yǔ)句——條件控制語(yǔ)法格式:例:根據(jù)職務(wù)浮動(dòng)工資流程控制語(yǔ)句——循環(huán)控制在PL/SQL中循環(huán)控制的有以下四種:簡(jiǎn)單循環(huán)FOR循環(huán)WHERE循環(huán)用于游標(biāo)的FOR循環(huán)流程控制語(yǔ)句——循環(huán)控制在PL/SQL中循環(huán)控制的有以下四種循環(huán)控制——簡(jiǎn)單循環(huán)語(yǔ)法格式:LOOP〈語(yǔ)句1〉;〈語(yǔ)句2〉;…EXITWHEN〈條件〉;ENDLOOP;例:把數(shù)值1到50順序插入表中。V_counter:=1;LOOPINSERTINTOtemp_tableVALUES(v_counter);EXITWHENv_counter>50;V_count:=v_count+1;ENDLOOP;循環(huán)控制——簡(jiǎn)單循環(huán)語(yǔ)法格式:例:把數(shù)值1到50順序插入表中循環(huán)控制——FOR循環(huán)語(yǔ)法格式:FOR〈循環(huán)變量〉IN[REVERSE]〈下界〉..〈上界〉LOOP〈語(yǔ)句1〉;〈語(yǔ)句2〉;…ENDLOOP;REVERSE:使計(jì)數(shù)器由上界到下界遞減計(jì)數(shù)例:把數(shù)值1到50順序插入表中。FORv_counterIN1..50LOOPINSERTINTOtemp_tableVALUES(v_counter);ENDLOOP;循環(huán)控制——FOR循環(huán)語(yǔ)法格式:例:把數(shù)值1到50順序插入表循環(huán)控制——WHILE循環(huán)語(yǔ)法格式:WHILE〈條件〉LOOP〈語(yǔ)句1〉;〈語(yǔ)句2〉;…ENDLOOP;例:把數(shù)值1到50順序插入表中。V_counter:=1;WHILEv_counter<=50LOOPINSERTINTOtemp_tableVALUES(v_counter);V_count:=v_count+1;ENDLOOP;循環(huán)控制——WHILE循環(huán)語(yǔ)法格式:例:把數(shù)值1到50順序插跳轉(zhuǎn)控制語(yǔ)句語(yǔ)法格式:<<標(biāo)號(hào)>>……GOTO<<標(biāo)號(hào)>>;
在進(jìn)行PL/SQL編程時(shí),盡量避免或不用GOTO語(yǔ)句,因?yàn)檫@種無(wú)條件的跳轉(zhuǎn)語(yǔ)句打破了程序的邏輯性,有悖于自頂向下的編程風(fēng)格.跳轉(zhuǎn)控制語(yǔ)句語(yǔ)法格式:PL/SQL游標(biāo)的使用游標(biāo)(CURSOR)的功能,是ORALCE系統(tǒng)為了將所有查詢結(jié)果返回給用戶程序而提供的。一個(gè)游標(biāo),實(shí)際上是在內(nèi)存中開(kāi)辟一個(gè)工作區(qū),它對(duì)應(yīng)一條SELECT語(yǔ)句。當(dāng)打開(kāi)游標(biāo)時(shí),就是執(zhí)行游標(biāo)所對(duì)應(yīng)的SELECT語(yǔ)句,并將其查詢結(jié)果放入工作區(qū),并且指針指向工作區(qū)的首部。通過(guò)光標(biāo)上的操作可以把這些記錄檢索到客戶端的應(yīng)用程序。CURSOR內(nèi)存區(qū)POINTERSELECT…INTO…:只能查詢數(shù)據(jù)庫(kù)的單條記錄,并把記錄的數(shù)據(jù)賦給變量。PL/SQL游標(biāo)的使用游標(biāo)(CURSOR)的功能,是ORAL游標(biāo)——定義和操縱游標(biāo)步驟:定義游標(biāo)打開(kāi)游標(biāo)從游標(biāo)中取值關(guān)閉游標(biāo)游標(biāo)——定義和操縱游標(biāo)步驟:定義游標(biāo)定義游標(biāo),就是定義一個(gè)游標(biāo)名,以及與其相對(duì)應(yīng)的SELECT語(yǔ)句。語(yǔ)法格式:CURSOR〈游標(biāo)名〉IS〈SELECT子句〉;示例:定義一個(gè)包含所有雇員記錄的游標(biāo)。cursorcur_empisselect*fromemp;定義游標(biāo)打開(kāi)游標(biāo)打開(kāi)游標(biāo),就是執(zhí)行游標(biāo)所對(duì)應(yīng)的SELECT語(yǔ)句,將其查詢結(jié)果放入工作區(qū),并且指針指向工作區(qū)的首部。語(yǔ)法格式:OPEN〈游標(biāo)名〉;打開(kāi)游標(biāo)從游標(biāo)中取值取值工作是將游標(biāo)工作區(qū)中的數(shù)據(jù)取出一行,放入指定的輸出變量中。語(yǔ)法格式:FETCH〈游標(biāo)名〉INTO〈變量1〉,〈變量2〉…;示例:fetchcur_empintov_empno,v_ename,v_sal,v_comm,v_deptno關(guān)閉游標(biāo)釋放與該游標(biāo)相關(guān)的資源。語(yǔ)法格式:CLOSE<游標(biāo)名>;示例:closecur_emp;從游標(biāo)中取值游標(biāo)的屬性從游標(biāo)工作區(qū)中逐一地取數(shù)據(jù),可以在循環(huán)中完成。但循環(huán)的開(kāi)始以及結(jié)束,需以游標(biāo)屬性為依據(jù)。游標(biāo)屬性有:%ISOPEN:判斷游標(biāo)是否被打開(kāi)%NOTFOUND:判斷何時(shí)中斷循環(huán)%FOUND:與%NOTFOUND相反%ROWCOUNT:實(shí)際從游標(biāo)工作區(qū)抽取的記錄數(shù)示例:Opencur_emp;Loopfetchcur_empintov_empno,v_ename,v_sal,v_deptno;exitwhencur_emp%NOTFOUND;Endloop;游標(biāo)的屬性從游標(biāo)工作區(qū)中逐一地取數(shù)據(jù),可以在循環(huán)中完成游標(biāo)——用于游標(biāo)的FOR循環(huán)游標(biāo)的FOR循環(huán),是一種簡(jiǎn)單的游標(biāo)操作方法,系統(tǒng)隱式地進(jìn)行游標(biāo)的打開(kāi)、提取數(shù)據(jù)、循環(huán)、關(guān)閉。格式:
FOR〈記錄變量〉IN〈游標(biāo)名〉LOOP〈語(yǔ)句…>;
ENDLOOP;<記錄變量>:由系統(tǒng)隱含定義的記錄名示例:Declarecursorcur_empisselect*fromemp;Beginforv_empincur_emploop
DBMS_OUTPUT.PUT_LINE(v_emp.ename);
DBMS_OUTPUT.PUT_LINE(v_emp.sal);endloop;End;游標(biāo)——用于游標(biāo)的FOR循環(huán)游標(biāo)的FOR循環(huán),是一種簡(jiǎn)一個(gè)完整的示例例:建立一存儲(chǔ)過(guò)程,根據(jù)職務(wù)修改工資CREATEORREPLACEPROCEDUREp_update_salASCURSORcur_empISSELECT*FROMemp;v_empcur_emp%ROWTYPE;BEGINOPENcur_emp;LOOPFETCHcur_empINTOv_emp;EXITWHENcur_emp%NOTFOUND;IFv_emp.job=‘MANAGER’THENv_emp.sal:=v_emp.sal*1.3;ELSIFv_emp.job=‘SALESMAN’THENv_emp.sal:=v_emp.sal*1.2;ELSEv_emp.sal:=v_emp.sal*1.1;ENDIF;UPDATEempSETsal=v_emp.salWHEREempno=v_emp.empno;ENDLOOP;CLOSEcur_emp;COMMIT;END;一個(gè)完整的示例例:建立一存儲(chǔ)過(guò)程,根據(jù)職務(wù)修改工資ELSIF一個(gè)完整的示例(用FOR循環(huán))CREATEPROCEDUREp_update_salASCURSORcur_empISSELECT*FROMemp;BEGINFORv_empINcur_empLOOPIFv_emp.job=‘MANAGER’THENv_emp.sal:=v_emp.sal*1.3;ELSIFv_emp.job=‘SALESMAN’THENv_emp.sal:=v_emp.sal*1.2;ELSEv_sal:=v_sal*1.1;ENDIF;UPDATEempSETsal=v_emp.salWHEREempno=v_emp.empno;ENDLOOP;COMMIT;END;一個(gè)完整的示例(用FOR循環(huán))CREATEPROCEDUR示例DECLARECURSORc1isSELECTename,empno,salFROMempORDERBYsalDESC;--startwithh
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 航空服務(wù)成本控制
- 網(wǎng)絡(luò)設(shè)備代收款協(xié)議書(shū)
- 電力公司會(huì)計(jì)崗位協(xié)議
- 跨區(qū)域投資二手房買(mǎi)賣(mài)合同模板
- 地下人行通道盾構(gòu)機(jī)租賃合同
- 美容設(shè)備租賃協(xié)議
- 教育行業(yè)加班輔導(dǎo)計(jì)劃
- 專利申請(qǐng)委托協(xié)議
- 歷史文化街區(qū)綠化施工合同
- 藝術(shù)設(shè)計(jì)教師勞動(dòng)合同模板
- 2024至2030年中國(guó)別墅行業(yè)投資前景分析預(yù)測(cè)及未來(lái)趨勢(shì)發(fā)展預(yù)測(cè)報(bào)告
- 初中七年級(jí)上冊(cè)綜合實(shí)踐活動(dòng) 低碳生活從我做起 教學(xué)設(shè)計(jì)
- 2024年金融貸款居間服務(wù)合同樣本(四篇)
- 2024中石油校園招聘高頻考題難、易錯(cuò)點(diǎn)模擬試題(共500題)附帶答案詳解
- 醫(yī)師定期考核(簡(jiǎn)易程序)練習(xí)及答案
- 2022-2023學(xué)年北京市海淀區(qū)清華附中八年級(jí)(上)期中數(shù)學(xué)試卷【含解析】
- 2024-2030年中國(guó)會(huì)計(jì)師事務(wù)所行業(yè)深度分析及發(fā)展前景與發(fā)展戰(zhàn)略研究報(bào)告
- 2024年國(guó)有企業(yè)新質(zhì)生產(chǎn)力調(diào)研報(bào)告
- 2024年安全員A證考試試題庫(kù)附答案
- 2024年國(guó)家開(kāi)放大學(xué)電大《金融學(xué)》形考任務(wù)答案
- 2022版義務(wù)教育(歷史)課程標(biāo)準(zhǔn)(附課標(biāo)解讀)
評(píng)論
0/150
提交評(píng)論