《應(yīng)用程序結(jié)構(gòu)》PPT課件.ppt

上傳人:za****8 文檔編號(hào):15816181 上傳時(shí)間:2020-09-08 格式:PPT 頁(yè)數(shù):82 大?。?86KB
收藏 版權(quán)申訴 舉報(bào) 下載
《應(yīng)用程序結(jié)構(gòu)》PPT課件.ppt_第1頁(yè)
第1頁(yè) / 共82頁(yè)
《應(yīng)用程序結(jié)構(gòu)》PPT課件.ppt_第2頁(yè)
第2頁(yè) / 共82頁(yè)
《應(yīng)用程序結(jié)構(gòu)》PPT課件.ppt_第3頁(yè)
第3頁(yè) / 共82頁(yè)

下載文檔到電腦,查找使用更方便

14.9 積分

下載資源

還剩頁(yè)未讀,繼續(xù)閱讀

資源描述:

《《應(yīng)用程序結(jié)構(gòu)》PPT課件.ppt》由會(huì)員分享,可在線閱讀,更多相關(guān)《《應(yīng)用程序結(jié)構(gòu)》PPT課件.ppt(82頁(yè)珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。

1、1,Oracle 數(shù)據(jù)庫(kù)系統(tǒng)第12章 應(yīng)用程序結(jié)構(gòu),2,本章要點(diǎn),理解子程序(過程、函數(shù))及包的概念 掌握如何創(chuàng)建、執(zhí)行和刪除過程、函數(shù)及包的方法 靈活使用過程、函數(shù)及包書寫PL/SQL程序 掌握創(chuàng)建和測(cè)試DML觸發(fā)器、instead-of數(shù)據(jù)庫(kù)觸發(fā)器以及系統(tǒng)觸發(fā)器 了解數(shù)據(jù)庫(kù)觸發(fā)器的使用時(shí)機(jī)和限制,3,子程序,子程序: PL/SQL的過程和函數(shù)統(tǒng)稱為子程序 匿名塊: 以DECLARE或BEGIN開始,每次提交都被編譯。匿名塊不在數(shù)據(jù)庫(kù)中存儲(chǔ)并且不能直接從其他PL/SQL塊中調(diào)用。 命名塊:除匿名塊之外的其他塊。包括過程,函數(shù),包和觸發(fā)器??梢栽跀?shù)據(jù)庫(kù)中存儲(chǔ)并在適當(dāng)?shù)臅r(shí)候運(yùn)行。,4,子程序的優(yōu)

2、點(diǎn),具有可擴(kuò)展性 可以自定義 PL/SQL 語(yǔ)言以滿足應(yīng)用程序的需要 提高可復(fù)用性和可維護(hù)性 子程序只要有效,就完全可以用于任何數(shù)目的應(yīng)用程序中 簡(jiǎn)化了維護(hù)/優(yōu)化過程,因?yàn)槿绻x更改只有子程序受到影響,5,創(chuàng)建子程序,創(chuàng)建過程(語(yǔ)法如下),CREATE OR REPLACE PROCEDURE procedure_name (argumentIN|OUT|IN OUTtype, ... argument IN| OUT| IN OUT type) IS| AS procedure_body,6,創(chuàng)建過程,過程的結(jié)構(gòu)應(yīng)具有下面所示的特征:,CREATE OR REPLACE PROCEDURE

3、 procedure_name parameter_list AS /*Declarative section is here*/ BEGIN /*Executable section is here*/ EXCEPTION /*Exception section is here*/ END procedure_name;,7,創(chuàng)建過程,CREATE OR REPLACE PROCEDURE search_emp (p_empno IN NUMBER,p_ename OUT VARCHAR2(20), p_deptno OUT NUMBER) IS v_name VARCHAR2(20); v

4、_deptno NUMBER; BEGIN SELECT ENAME,DEPTNO INTO v_name, v_deptno FROM EMP WHERE EMPNO= p_empno; p_ename := v_name ; p_deptno := v _deptno ; EXCEPTION WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE(EMPNO:|| p_empno||NO EXIST ); END search_emp;,8,創(chuàng)建函數(shù),函數(shù)與過程的比較: 兩者都帶有參數(shù),參數(shù)可以具有模式。 兩者都是PL/SQL語(yǔ)句塊的不同形式,都有聲明段、可執(zhí)行段以及

5、異常段。 兩者都可以存儲(chǔ)在數(shù)據(jù)庫(kù)中或在語(yǔ)句塊中聲明 兩者不同的是,過程調(diào)用本身是一個(gè)PL/SQL語(yǔ)句,而函數(shù)調(diào)用是作為表達(dá)式的一部分被調(diào)用的。,9,函數(shù)的語(yǔ)法,非常類似于創(chuàng)建過程的語(yǔ)法。其定義如下:,CREATE OR REPLACE FUNCTION function_name ( argumentIN | OUT | IN OUT type, ... argumentIN | OUT | IN OUT type) RETURN return_typeIS | AS function_body,10,RETURN語(yǔ)句,RETURN語(yǔ)句用來把控制返回到調(diào)用環(huán)境中。,語(yǔ)法如下: RETURN e

6、xpression;,當(dāng)該語(yǔ)句執(zhí)行時(shí),如果表達(dá)式的類型與定義不符,該表達(dá)式將被轉(zhuǎn)為函數(shù)定義子句RETURN中指定的類型,同時(shí),控制將立即返回到調(diào)用環(huán)境。,11,刪除過程和函數(shù),刪除操作是將過程或函數(shù)從數(shù)據(jù)字典中刪除。,刪除過程的語(yǔ)法如下,刪除函數(shù)的語(yǔ)法如下:,DROP PROCEDURE procedure_name;,DROP FUNCTION function_name ;,12,子程序參數(shù),1、參數(shù)模式 2、在形參和實(shí)參之間傳遞數(shù)值 3、對(duì)形參的約束 4、子程序內(nèi)部引發(fā)的異常 5、按引用和按值傳遞參數(shù) 6、使用NOCOPY參數(shù) 7、不帶參數(shù)的子程序 8、定位符和命名符 9、參數(shù)缺省值,1

7、3,1、參數(shù)模式,過程和函數(shù)的參數(shù)可以有不同的模式,并可以按值或按引用進(jìn)行傳遞。,14,DECLARE -- Variables describing the new employee v_NewEmpNo emp.empno%TYPE:=7968; v_NewName emp.ename%TYPE:=Cynthia; v_NewJob emp.job%TYPE:=Manager; v_Mgr emp.mgr%TYPE:=7839; v_HireDate emp.hiredate%TYPE:=20-SEP-03; v_Sal emp.sal%TYPE:=2010; v_Comm m%TYPE:

8、=NULL; v_DeptNo emp.deptno%TYPE:=40; BEGIN -- Add Cynthia to the database. HireNewEmployee(v_EmpNo,v_EName,v_Job,v_Mgr, v_HireDate,v_Sal,v_Comm,v_DeptNo); END;,舉例,15,參數(shù)模式,16,2、在形參和實(shí)參之間傳遞數(shù)值,文字或常數(shù)作為實(shí)參 因?yàn)閺?fù)制功能的使用,對(duì)應(yīng)于參數(shù)IN OUT或OUT的實(shí)參必須是變量,而不能是常數(shù)或表達(dá)式。也就是說,程序必須提供返回的變量的存儲(chǔ)位置。 編譯檢查 PL/SQL編譯器在創(chuàng)建過程時(shí)將對(duì)合法的賦值進(jìn)行檢查。

9、從OUT參數(shù)讀取數(shù)據(jù),17,3、對(duì)形參的約束,調(diào)用過程時(shí),實(shí)參的值將被傳入該過程,這些實(shí)參在該過程內(nèi)部以引用的方式使用形參。 同時(shí),作為參數(shù)傳遞機(jī)制一部分,對(duì)變量的約束也傳遞給該過程。 在過程的聲明中,強(qiáng)制指定參數(shù)CHAR和VARCHAR2的長(zhǎng)度,以及指定NUMBER參數(shù)的精度或小數(shù)點(diǎn)后位數(shù)都是非法的,這是因?yàn)檫@些約束可以從實(shí)參中獲得。,18,錯(cuò)誤聲明: CREATE OR REPLACE PROCEDURE ParameterLength( p_Parameter1 IN OUT VARCHAR2(10), p_Parameter2 IN OUT NUMBER(3,1)) AS BEGIN

10、p_Parameter1:=abcdefghijklm; p_Parameter2:=12.3; END ParameterLength;,舉例,正確聲明: CREATE OR REPLACE PROCEDURE ParameterLength( p_Parameter1 IN OUT VARCHAR2, p_Parameter2 IN OUT NUMBER) AS BEGIN p_Parameter1:=abcdefghijklmno; p_Parameter2:=12.3; END ParameterLength;,19,4、子程序內(nèi)部引發(fā)的異常,如果錯(cuò)誤發(fā)生在子程序的內(nèi)部,就會(huì)引發(fā)異常。

11、 該異常既可以是由用戶定義的,也可以是程序中預(yù)定義的。 如果引發(fā)異常的過程中沒有處理該錯(cuò)誤的異常處理程序(或該異常發(fā)生在該異常處理程序的內(nèi)部),根據(jù)異常的傳播規(guī)則,控制將立即轉(zhuǎn)出該過程返回其調(diào)用環(huán)境。然而,在這種情況下,OUT和IN OUT形參的值并沒有返回到實(shí)參。這些實(shí)參仍將被設(shè)置為調(diào)用前的值。,20,5、按引用和按值傳遞參數(shù),子程序參數(shù)可以按即按引用或按值傳遞。 按引用傳遞:一個(gè)指向?qū)崊⒌闹羔槍⒈粋鬟f到對(duì)應(yīng)的形參。 按值傳遞:實(shí)參的值將被賦予對(duì)應(yīng)的形參。,21,6、使用NOCOPY參數(shù),語(yǔ)法如下:,parameter_name mode NOCOPY datatype,parameter_

12、name是參數(shù)名 mode是參數(shù)的模式(IN,OU,IN OUT) datatype是參數(shù)的數(shù)據(jù)類型 如果使用了NOCOPY,則PL/SQL編譯器將按引用傳遞參數(shù),而不按值傳遞 由于NOCOPY是一個(gè)編譯選項(xiàng),而非指令,所以該選項(xiàng)不總是被采用。,22,使用NOCOPY時(shí)的異常語(yǔ)義,當(dāng)參數(shù)通過引用傳遞時(shí),任何對(duì)實(shí)參的修改也將引起對(duì)其對(duì)應(yīng)形參的修改,這是因?yàn)樵搶?shí)參和形參同時(shí)位于相同的存儲(chǔ)單元的緣故。換句話說,如果過程退出時(shí)沒有處理異常而形參已被修改的話,則該形參對(duì)應(yīng)的實(shí)參的原始值也將被修改。,23,使用NOCOPY的限制,在某些情況下,NOCOPY將被編譯器忽略,這時(shí)的參數(shù)仍將按值傳遞。在這種情況

13、下,編譯器不會(huì)報(bào)告編譯錯(cuò)誤。由于NOCOPY是一個(gè)提示項(xiàng)(Hint),編譯器可以決定是否執(zhí)行該項(xiàng)。,24,使用NOCOPY的優(yōu)點(diǎn),NOCOPY的主要優(yōu)點(diǎn)是可以提高程序的效率。當(dāng)我們傳遞大型PL/SQL表時(shí),其優(yōu)越性特別顯著。 按值傳遞IN OUT模式的參數(shù)所使用的時(shí)間遠(yuǎn)遠(yuǎn)大于按引用傳遞IN和IN OUT NOCOPY參數(shù)所使用的時(shí)間。,25,7、不帶參數(shù)的子程序,如果過程沒有參數(shù)的話,就不需要在該過程調(diào)用聲明中或在其過程調(diào)用中使用括弧。函數(shù)也具有類似的情況。 函數(shù)與過程類似 。,26,8、定位符和命名符,實(shí)參都通過位置與對(duì)應(yīng)的形參相關(guān)聯(lián),參數(shù)間的這種對(duì)應(yīng)法稱為定位符(Positional No

14、tation)。 命名符中,對(duì)于每一個(gè)參數(shù),都包含了形參和實(shí)參。這就允許我們?cè)谛枰獣r(shí)重新安排參數(shù)的順序。 定位符和命名符也可以在同一個(gè)調(diào)用中混合使用。但是,該類調(diào)用的第一個(gè)參數(shù)必須是通過位置指定,而其余的參數(shù)可以根據(jù)名稱指定。,27,定位符與命名符的對(duì)比,28,9、參數(shù)缺省值,過程或函數(shù)的形參可以具有缺省值。如果一個(gè)參數(shù)有缺省值的話,該參數(shù)就可以不從調(diào)用環(huán)境中傳遞。如果傳遞了一個(gè)值,則實(shí)參的值將取代缺省值。,parameter_name mode parameter_type:=|DEFAULT initial_value,29,過程與函數(shù)的比較,相同點(diǎn): 通過設(shè)置OUT參數(shù),過程和函數(shù)都可以

15、返回一個(gè)以上的值。 過程和函數(shù)都可以具有聲明段、可執(zhí)行段和異常處理段。 過程和函數(shù)都可以接受缺省值。 都可以使用位置或名稱對(duì)應(yīng)法調(diào)用過程和函數(shù)。 過程和函數(shù)都可以接受參數(shù)NOCOPY(僅Oracle8i及更高版本支持)。,30,過程與函數(shù)的比較,區(qū)別: 如果返回值在一個(gè)以上時(shí),用過程為好。 如果只有一個(gè)返回值,使用函數(shù)就可以滿足要求。 函數(shù)還可以從SQL語(yǔ)句中調(diào)用。,31,過程、函數(shù)練習(xí),1、創(chuàng)建一個(gè)過程,向DEPT插入一個(gè)新單位,通過兩個(gè)變量提供單位編號(hào)和單位名稱 2、創(chuàng)建一個(gè)過程,修改DEPT中的某一單位的單位名稱,過程應(yīng)包括異常處理。 3、創(chuàng)建一函數(shù),以確認(rèn)指定的DEPTNO是否存在,返

16、回BOOLEAN型值 4、創(chuàng)建一個(gè)過程,新增一員工,調(diào)用上題函數(shù)判斷DEPTNO的存在,如果不存在發(fā)出警告,員工各數(shù)據(jù)項(xiàng)均有默認(rèn)值。,32,包,包是由存儲(chǔ)在一起的相關(guān)對(duì)象組成的PL/SQL結(jié)構(gòu)。 包有兩個(gè)獨(dú)立的部分:說明和包體,這兩部分獨(dú)立地存儲(chǔ)在數(shù)據(jù)字典中。 包只能被存儲(chǔ),而且不可能是局部的。,33,包的說明,語(yǔ)法:CREATE OR REPLACE PACKAGE package_nameIS|AS type_definition| procedure_specification| function_specification| variable_declaration| exceptio

17、n_declaration| cursor_declaration| pragma_declaration END package_name;,34,包的說明,包的說明:也叫做包頭,包含了有關(guān)包的內(nèi)容的信息。該部分中不包括任何子程序代碼。,35,包體,包體是一個(gè)獨(dú)立于包頭的數(shù)據(jù)字典對(duì)象。 包體只能在包頭完成編譯后才能進(jìn)行編譯。 包體中包含包頭中預(yù)先聲明的子程序的代碼。 除此之外,包體還可以包括對(duì)包體是全局的其他聲明,但這些附加說明對(duì)于說明部分是不可見的。 包體是可選的。如果包頭中不包含任何過程或函數(shù)的話(只有變量聲明,游標(biāo),類型等),那么包體就不必存在。 包頭中的任何預(yù)先聲明不能出現(xiàn)在包體中。

18、包頭和包體中的過程和函數(shù)的說明必須一致,其中包括子程序名和其參數(shù)名,以及參數(shù)的模式。,36,包和作用域,包頭中聲明的任何對(duì)象都是在其作用域中,并且可在其外部使用包名作為前綴對(duì)其進(jìn)行引用。 在包體內(nèi),包頭中的對(duì)象可以不帶包名進(jìn)行直接引用。 在包體中可以包含私有聲明。這些定義的類型和數(shù)據(jù)項(xiàng)可以且只能在包體內(nèi)部使用。,37,重載封裝子程序,在包的內(nèi)部,過程和函數(shù)可以被重載。也就是說,可以有一個(gè)以上具有相同名稱但參數(shù)不同的過程或函數(shù)。 如果兩個(gè)子程序的參數(shù)僅在名稱和模式上不同,則這兩個(gè)過程不能重載。 不能只根據(jù)兩個(gè)過程的不同返回類型對(duì)其進(jìn)行重載。 重載函數(shù)的參數(shù)的類型系列(type family)必須

19、不同,也就是說,不能對(duì)同一個(gè)類型系列的過程進(jìn)行重載。,38,包的初始化,定義: 當(dāng)?shù)谝淮握{(diào)用封裝子程序時(shí),或者對(duì)封裝變量或類型進(jìn)行引用時(shí),就對(duì)包進(jìn)行了實(shí)例化。 在大多數(shù)情況下,在會(huì)話內(nèi)首次對(duì)一個(gè)包進(jìn)行實(shí)例化操作時(shí),要運(yùn)行初始化代碼。,39,小結(jié),命名塊是已經(jīng)命名并保存的PL/SQL語(yǔ)句塊,程序中可以重復(fù)使用它們。存儲(chǔ)子程序是保存在數(shù)據(jù)庫(kù)中的命名塊。 PL/SQL有兩種類型子程序:過程和函數(shù)。子程序是一種可以執(zhí)行操作和接收參數(shù)的命名塊。 子程序的結(jié)構(gòu)是標(biāo)準(zhǔn)的PL/SQL結(jié)構(gòu),包括聲明段、可執(zhí)行段和異常處理段。 過程是一個(gè)PL/SQL語(yǔ)句,而函數(shù)是表達(dá)式的一部分。 函數(shù)使用一些參數(shù),并且必須返回一

20、個(gè)值。在聲明段包括了一個(gè)RETURN語(yǔ)句,指出返回值的數(shù)據(jù)類型,在可執(zhí)行段至少包括一個(gè)RETURN語(yǔ)句,但只會(huì)執(zhí)行其中一個(gè)。過程中的RETURN語(yǔ)句是不同的,它只是控制執(zhí)行語(yǔ)句的流程。 形參指的是子程序聲明段中的參數(shù)。實(shí)參是用來在調(diào)用子程序時(shí)向子程序傳遞值的變量。形參具有3種模式:IN、OUT和IN OUT。,40,小結(jié),子程序參數(shù)可以按兩種方式傳遞參數(shù)值:按引用或按值傳遞。當(dāng)參數(shù)是按引用傳遞時(shí),一個(gè)指向?qū)崊⒌闹羔槍⒈粋鬟f到對(duì)應(yīng)的形參。當(dāng)參數(shù)是按值傳遞時(shí),實(shí)參的值將被賦予對(duì)應(yīng)的形參。 將值傳遞到參數(shù)可以使用兩種方法:占位符和命名符。 包是由存儲(chǔ)在一起的相關(guān)對(duì)象組成的PL/SQL結(jié)構(gòu)。包有兩個(gè)獨(dú)

21、立的部分:說明和包體,這兩部分獨(dú)立地存儲(chǔ)在數(shù)據(jù)字典中。 在包的說明中聲明的對(duì)象是全局的,可以在包外引用它們。在包體聲明的所有元素都是局部的,只能在包體中引用它們,而不能在包外引用。 重載是包的一種特性,它允許創(chuàng)建多個(gè)具有相同名稱的子程序。這允許同一個(gè)子程序可以接受不同類型的參數(shù)。重載子程序的參數(shù)必須在參數(shù)數(shù)量、數(shù)據(jù)類型系列或者順序上有所不同。,41,局部子程序,局部子程序:是一個(gè)在PL/SQL語(yǔ)句塊的聲明段中聲明的子程序。 子函數(shù)只在其聲明的語(yǔ)句塊中可見,其作用域從聲明點(diǎn)開始到該語(yǔ)句塊結(jié)束為止。其他語(yǔ)句塊不能調(diào)用該函數(shù),因?yàn)樵摵瘮?shù)對(duì)其他語(yǔ)句塊來說是不可見的。,42,局部子程序(續(xù)),局部子程序

22、也可以聲明為存儲(chǔ)子程序聲明段的一部分 局部子程序的位置:任何局部子程序都必須在聲明段的最后進(jìn)行聲明 預(yù)先聲明 :局部PL/SQL子程序的名稱是標(biāo)識(shí)符,必須在被引用前聲明。 局部子程序也可以重載,43,存儲(chǔ)子程序和局部子程序的比較,44,存儲(chǔ)子程序和包的注意事項(xiàng),優(yōu)勢(shì): 可以由多個(gè)數(shù)據(jù)庫(kù)用戶共享 隱含影響: 存儲(chǔ)子程序間的依賴性 包狀態(tài)的處理方法 運(yùn)行存儲(chǔ)子程序 包所需要的特權(quán),45,子程序的依賴性,依賴:數(shù)據(jù)字典記錄了存儲(chǔ)過程或函數(shù)所引用的所有Oracle對(duì)象。該過程或函數(shù)就依賴于這些存儲(chǔ)的對(duì)象。 自動(dòng)重編譯:如果一個(gè)依賴對(duì)象失效,PL/SQL引擎將在該對(duì)象再次被調(diào)用時(shí)對(duì)其重新進(jìn)行編譯。 包的

23、依賴性:包體的變化不會(huì)導(dǎo)致修改包頭。因此,其他依賴于該包頭的對(duì)象也不需要進(jìn)行重新編譯。如果該包頭有變化,則會(huì)使包體自動(dòng)失效,這是因?yàn)樵摪w依賴于包頭 。 如何確定無效 :通過數(shù)據(jù)字典在不斷地跟蹤對(duì)象間依賴關(guān),46,包運(yùn)行時(shí)狀態(tài),當(dāng)?shù)谝淮螌?shí)例化一個(gè)包時(shí),將從磁盤中讀入該包的偽代碼并將其放入系統(tǒng)全局工作區(qū)SGA的共享池中。 包的運(yùn)行時(shí)狀態(tài),即打包的變量和游標(biāo),則存放在用戶全局區(qū)(UGA)的會(huì)話存儲(chǔ)區(qū)中。這就保證了每個(gè)會(huì)話都將有其運(yùn)行時(shí)狀態(tài)的副本。 可串行復(fù)用包和非串行復(fù)用包:PL/SQL 2.3版及更高版本允許程序員對(duì)包做可串行復(fù)用標(biāo)志。,47,包運(yùn)行時(shí)狀態(tài),48,EXECUTE特權(quán),為了能夠?qū)Ρ?/p>

24、進(jìn)行訪問,必須使用SELECT,INSERT,UPDATE和DELETE對(duì)象特權(quán)。GRANT語(yǔ)句把這些特權(quán)賦予數(shù)據(jù)庫(kù)用戶或角色。對(duì)于存儲(chǔ)子程序和包來說,相關(guān)的特權(quán)是EXECUTE。,49,50,51,存儲(chǔ)子程序和角色,子程序使用顯式地(而不是通過角色)授權(quán)其所有者的特權(quán)而執(zhí)行。 為了使通過角色授權(quán)的特權(quán)作用在存儲(chǔ)子程序和觸發(fā)器內(nèi)被使用,每次運(yùn)行過程時(shí),必須對(duì)該特權(quán)進(jìn)行檢查。,52,調(diào)用者的權(quán)限與定義者的權(quán)限,Oracle8i提供了不同的外部引用解決方案。在調(diào)用者的權(quán)限子程序中,外部引用是通過調(diào)用者而不是所有者的特權(quán)設(shè)置而執(zhí)行的。調(diào)用者的權(quán)限程序是通過使用AUTHID子句而創(chuàng)建,該語(yǔ)句只適用于獨(dú)

25、立子程序、包說明和對(duì)象類型說明。 在包內(nèi)部或?qū)ο箢愋椭械莫?dú)立子程序必須都是調(diào)用者子程序或都是定義者子程序,而不能混合。,53,AUTHID的語(yǔ)法如下: CREATE OR REPLACE FUNCTION function_name parameter_list RETURN return_type AUTHID CURRENT_USER | DEFINER IS | AS function_body; CREATE OR REPLACE PROCEDURE procedure_name parameter_list AUTHID CURRENT_USER | DEFINER IS | AS

26、function_body; CREATE OR REPLACE PACKAGE package_spec_name AUTHID CURRENT_USER | DEFINER IS | AS package_spec; CREATE OR REPLACE TYPE type_name AUTHID CURRENT_USER | DEFINER IS | AS OBJECT type_spec;,54,默認(rèn)參數(shù),從過程化語(yǔ)句中調(diào)用一個(gè)函數(shù)時(shí),如果該函數(shù)有形參的話,可以使用其缺省值。然而,如果從SQL語(yǔ)句調(diào)用函數(shù)時(shí),必須指定所有參數(shù)。 必須使用定位符(Positinal Notation),而不

27、能使用命名符(Name Notation)。,55,包的輔助功能,共享池鎖定 包體長(zhǎng)度的限制 優(yōu)化參數(shù),56,共享池鎖定,DBMS_SHARED_POOL包允許程序員把一個(gè)對(duì)象鎖定在共享池中。 當(dāng)該對(duì)象被鎖定后,除非由程序申請(qǐng)對(duì)其清除,否則無論共享池有多滿,也不管是否有程序訪問該對(duì)象,該對(duì)象將常駐在共享池中。 這種處理方法有利于提高程序的運(yùn)行效率,因?yàn)閺南到y(tǒng)的磁盤重新裝入對(duì)象要進(jìn)行大量讀寫操作。鎖定對(duì)象還有助于最大限度地減少共享池的碎片。,57,包體長(zhǎng)度的限制,編譯器對(duì)包體長(zhǎng)度的限制如下 : Diana樹中的節(jié)點(diǎn)數(shù)。在Oracle8i之前的版本中,Diana節(jié)點(diǎn)的最大數(shù)目是32K,Oracle

28、8i以上版本將包體和類型體的限制擴(kuò)充到了64兆字節(jié)的容量。 編譯器生成的臨時(shí)中間變量的容量最多21K字節(jié)。 入口點(diǎn)的數(shù)量。一個(gè)包體最多可以有32K個(gè)入口點(diǎn),入口點(diǎn)可以是過程或函數(shù)。 字符串的數(shù)量。PL/SQL對(duì)字符串的限制單位是232。,58,觸發(fā)器,觸發(fā)器類似于函數(shù)和過程,它們都是具有聲明段、可執(zhí)行段和異常處理段的命名PL/SQL語(yǔ)句塊。像包一樣,觸發(fā)器必須在數(shù)據(jù)庫(kù)中存儲(chǔ)為獨(dú)立的對(duì)象。 主要用于: 維護(hù)那些通過創(chuàng)建表時(shí)的聲明約束無法實(shí)現(xiàn)的復(fù)雜的完整性約束。 通過記錄已進(jìn)行的改變以及是誰進(jìn)行了該項(xiàng)改變來檢查一個(gè)表中的信息。 當(dāng)一個(gè)表發(fā)生改變時(shí),自動(dòng)向其他程序發(fā)送需要采取行動(dòng)的信號(hào)。 在一個(gè)發(fā)布

29、-預(yù)訂環(huán)境中發(fā)布有關(guān)各種事件的信息。,59,觸發(fā)器的類型,觸發(fā)器主要有三種類型: DML INSTEAD-OF觸發(fā)器 系統(tǒng)觸發(fā)器。,60,DML觸發(fā)器,DML觸發(fā)器可以由DML語(yǔ)句激發(fā) 由DML語(yǔ)句的類型決定DML觸發(fā)器的類型。 DML觸發(fā)器可以在DML語(yǔ)句操作之前或之后激發(fā)。 DML觸發(fā)器也可以在行或語(yǔ)句操作上激發(fā) 。,61,INSTEAD-OF觸發(fā)器,INSTEAD-OF 觸發(fā)器是行級(jí)別的,執(zhí)行時(shí),激發(fā)它的DML語(yǔ)句不執(zhí)行。 只能定義在視圖上。 Oracle8及更高版本才提供。,62,系統(tǒng)觸發(fā)器,系統(tǒng)觸發(fā)器在發(fā)生諸如數(shù)據(jù)庫(kù)啟動(dòng)或關(guān)閉等系統(tǒng)事件時(shí)激發(fā),而不是在執(zhí)行DML語(yǔ)句時(shí)激發(fā)。 系統(tǒng)觸發(fā)

30、器也可以在DDL操作時(shí),如表的創(chuàng)建時(shí)被激發(fā)。,63,創(chuàng)建觸發(fā)器,CREATE OR REPLACE TRIGGER trigger_name BEFORE | AFTER | INSTEAD OF triggering_event referencing_clause WHEN trigger_condition FOR EACH ROW trigger_body;,,,,64,創(chuàng)建DML觸發(fā)器,65,DML觸發(fā)器例子,Create or replace trigger modi_emp before insert or update or delete on emp Begin if (to

31、_char(sysdate,HH24)not between 08and 17) or (to_char(sysdate,dy,nls_date_language=american) in (sat,sun)) then raise_application_error(-20000,費(fèi)工作時(shí)間不能修改職工信息); end if; End;,66,DML觸發(fā)器激發(fā)順序,如果存在語(yǔ)句之前的觸發(fā)器,先執(zhí)行該觸發(fā)器。 對(duì)于受語(yǔ)句影響每一行: 如果存在行之前的觸發(fā)器,執(zhí)行該觸發(fā)器。 執(zhí)行該語(yǔ)句本身。 如果存在行之后的觸發(fā)器,執(zhí)行該觸發(fā)器。 如果存在語(yǔ)句之后的觸發(fā)器,運(yùn)行該觸發(fā)器。,67,行級(jí)別觸發(fā)器的相

32、關(guān)標(biāo)識(shí)符,觸發(fā)語(yǔ)句處理每一行時(shí),行級(jí)別觸發(fā)器都激發(fā)一次。 在觸發(fā)器內(nèi)部,可以通過相關(guān)標(biāo)識(shí)符:old和:new訪問正在處理中的行的數(shù)據(jù)。 標(biāo)識(shí)符:old和:new也被稱為偽記錄。,68,: old和:new相關(guān)標(biāo)識(shí)符,注意:old標(biāo)識(shí)符對(duì)INSERT語(yǔ)句未定義,而:new標(biāo)識(shí)符對(duì)DELETE語(yǔ)句未定義。PL/SQL編譯器不會(huì)對(duì)在INSERT語(yǔ)句中使用的:old和在DELETE語(yǔ)句中使用的:new標(biāo)識(shí)符報(bào)錯(cuò),編譯的結(jié)果將使這兩者的字段值為NULL。,69,觸發(fā)器例子,Create or replace trigger score_change after update of score on gr

33、ade For each row Begin insert into table_score_change values(:old.sno,:o,:old.score,:new.score,sysdate); End;,70,WHEN子句,WHEN子句只適用于行級(jí)別觸發(fā)器。 如果使用該子句,觸發(fā)器體將只對(duì)滿足由WHEN子句指定條件的行而執(zhí)行。,語(yǔ)法:WHEN trigger_condition,71,觸發(fā)器謂詞,72,創(chuàng)建instead-of觸發(fā)器,instead-of觸發(fā)器用于以下兩種情況: 允許修改一個(gè)本來無法修改的視圖。 修改視圖中嵌套表列的列。,73,可更改的與不可更改的視圖,可更改視

34、圖:可以發(fā)出DML命令的視圖。 一般來說,視圖如果不包括下列命令中的任何一項(xiàng),它就是一個(gè)可更改視圖 。 1、集合操作符(UNION、UNION ALL、MINUS) 2、聚集函數(shù)(SUM、AVG等) 3、GROUP BY、CONNECT BY或START WITH子句 4、DISTINCT操作符 5、連接,74,instead-of觸發(fā)器,如果一個(gè)視圖是不可更改的,則可以在其上編寫一個(gè)instead-of觸發(fā)器來執(zhí)行正確的操作,從而使該視圖可更改。 如果需要進(jìn)行其他處理的話,也可以在可更改視圖上編寫instead-of觸發(fā)器。,75,創(chuàng)建系統(tǒng)觸發(fā)器,系統(tǒng)觸發(fā)器可以在兩種不同種類的事件(即DDL

35、或數(shù)據(jù)庫(kù))上激發(fā)。 DDL事件包括CREATE、ALTER或DROP語(yǔ)句。 而數(shù)據(jù)庫(kù)事件包括服務(wù)器的啟動(dòng)或關(guān)閉,用戶的登錄或退出,以及服務(wù)器錯(cuò)誤。,語(yǔ)法: CREATE OR REPLACE TRIGGER schema. trigger_name BEFORE | AFTER ddl_event_list| database_event_list ON DATABASE | schema.SCHEMA when_clause trigger_body;,76,系統(tǒng)DLL和數(shù)據(jù)庫(kù)事件,77,其他觸發(fā)器問題,觸發(fā)器名稱的命名空間(Name-space) 使用觸發(fā)器的各種限制和不同種類的觸發(fā)器體。

36、 與觸發(fā)器有關(guān)的權(quán)限問題,78,觸發(fā)器名稱,命名空間:是一組合法的可供對(duì)象作為名字使用的標(biāo)識(shí)符。過程、包和表都共享同一個(gè)命名空間,在一個(gè)數(shù)據(jù)庫(kù)模式范圍內(nèi),同一命名空間內(nèi)的所有的對(duì)象必須具有唯一的名稱。 觸發(fā)器隸屬于一個(gè)獨(dú)立的命名空間。也就是說,觸發(fā)器可以有與表和過程相同的名稱。然而,在一個(gè)模式范圍內(nèi),給定的名稱只能用于一個(gè)觸發(fā)器。,79,對(duì)觸發(fā)器的限制,觸發(fā)器不能發(fā)出任何事務(wù)控制語(yǔ)句,如COMMIT、ROLLBACK、SAVEPOINT或SET TRANSACTION。 由觸發(fā)器體調(diào)用的任何過程或函數(shù)都不能發(fā)出任何事務(wù)控制語(yǔ)句(除非在Oracle8i及更高版本中把它們聲明為自治的)。 觸發(fā)器體

37、不能聲明任何LONG或LONG RAW變量。而且,:new和:old也不能指向?yàn)橹x的表的LONG或LONG RAW類型的列。 在Oracle8及更高版本中,觸發(fā)器體中的代碼可以引用和使用LOB(大型對(duì)象)列,但不能修改該列的值。這個(gè)限制也適用于對(duì)象列。,80,觸發(fā)器權(quán)限,81,本章小結(jié),數(shù)據(jù)庫(kù)觸發(fā)器是根據(jù)一個(gè)事件執(zhí)行的PL/SQL語(yǔ)句塊。數(shù)據(jù)庫(kù)觸發(fā)器有三種類型:DML觸發(fā)器、instead-of觸發(fā)器和系統(tǒng)觸發(fā)器。 CREATE TRIGGER語(yǔ)句包括執(zhí)行時(shí)間選項(xiàng)(之前或之后),并且可以標(biāo)識(shí)為行級(jí)別和語(yǔ)句級(jí)別。 行級(jí)別觸發(fā)器對(duì)于DML事件影響的每一行激發(fā)。語(yǔ)句級(jí)別觸發(fā)器只對(duì)DML事件觸發(fā)一

38、次,而不管DML影響了多少行。 CREATE TRIGGER語(yǔ)句包括一個(gè)可選的WHEN子句,它可以檢查一個(gè)條件,決定是否應(yīng)該執(zhí)行觸發(fā)器。 相關(guān)性標(biāo)識(shí)符:OLD和:NEW允許引用DML操作的原始行值和新行值。 觸發(fā)器謂詞INSERTING、UPDATING和DELETING允許在一個(gè)觸發(fā)器中對(duì)于不同事件執(zhí)行不同的PL/SQL代碼。,82,本章小結(jié),Instead-of觸發(fā)器基于一個(gè)視圖,并允許通過視圖執(zhí)行DML操作。 系統(tǒng)觸發(fā)器是在DDL語(yǔ)句和系統(tǒng)事件上觸發(fā)的。 如果DML語(yǔ)句觸發(fā)了一個(gè)觸發(fā)器,并且這個(gè)觸發(fā)器嘗試引用該DML事件所處理的那個(gè)表,則將引發(fā)一個(gè)錯(cuò)誤。 ALTER TRIGGER語(yǔ)句允許編譯器禁用或啟用觸發(fā)器。 想要從系統(tǒng)中刪除一個(gè)觸發(fā)器,可以使用DROP TRIGGER語(yǔ)句。 USER_TRIGGERS數(shù)據(jù)字典視圖包含了所有觸發(fā)器聲明信息以及源代碼。,

展開閱讀全文
溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝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ù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(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ì)自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號(hào):ICP2024067431號(hào)-1 川公網(wǎng)安備51140202000466號(hào)


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺(tái),本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請(qǐng)立即通知裝配圖網(wǎng),我們立即給予刪除!