發(fā)文章
發(fā)文工具
撰寫
網(wǎng)文摘手
文檔
視頻
思維導(dǎo)圖
隨筆
相冊(cè)
原創(chuàng)同步助手
其他工具
圖片轉(zhuǎn)文字
文件清理
AI助手
留言交流
子程序和程序包總結(jié):子程序是命名的PL/SQL塊,可帶參數(shù)并可在需要時(shí)隨時(shí)調(diào)用。PL/SQL有兩種類型的子程序,即過(guò)程和函數(shù)。過(guò)程用于執(zhí)行特定的任務(wù),函數(shù)用于執(zhí)行任務(wù)并返回值。程序包是對(duì)相關(guān)類型、變量、常量、游標(biāo)、異常、過(guò)程和函數(shù)的封裝。程序包由包規(guī)范和包主體兩部分組成。包規(guī)范是包的接口,包含公用對(duì)象及其類型。包主體實(shí)現(xiàn)包規(guī)范中的游標(biāo)和子程序,包主體中的聲明僅限于在包內(nèi)使用。程序包中游標(biāo)的定義分為游標(biāo)規(guī)范和游標(biāo)主體兩部分。
語(yǔ)法及示例:1、存儲(chǔ)過(guò)程創(chuàng)建存儲(chǔ)過(guò)程的語(yǔ)法:CREATE [OR REPLACE] PROCEDURE procedure_name[(parameter_list)]{IS|AS}[local_declarations]BEGINexecutable_statements[EXCEPTIONexception_handlers]END [procedure_name];其中:procedure_name是過(guò)程的名稱。parameter_list是參數(shù)列表。local_declarations是局部聲明。executable_statements是可執(zhí)行語(yǔ)句。exception_handlers是異常處理程序。示例1:演示創(chuàng)建過(guò)程(參數(shù)列表中為IN參數(shù)賦予一個(gè)默認(rèn)值,不能為OUT、IN OUT參數(shù)賦予默認(rèn)值)create or replace procedure find_emp(emp_no in number:=7900)asempname varchar2(20);beginselect ename into empname from emp where empno=emp_no;dbms_output.put_line('雇員姓名是 '||empname);exceptionwhen no_data_found thendbms_output.put_line('雇員編號(hào)未找到');end find_emp;調(diào)用過(guò)程:EXECUTE procudure_name(parameters_list);也可以在過(guò)程里面調(diào)用,直接寫上procudure_name而不必寫EXECUTE。
示例2:演示創(chuàng)建帶OUT參數(shù)的過(guò)程create or replace procedure test(value1 varchar2,value2 out number)isidentity number;beginselect sal into identity from emp where empno=value1;if identity<2000 thenvalue2:=1000;elsevalue2:=500;end if;end;
調(diào)用帶OUT參數(shù)的過(guò)程:declarevalue2 number;begintest('7900',value2);dbms_output.put_line(value2);end;
示例3:演示創(chuàng)建帶IN OUT參數(shù)的過(guò)程create or replace procedure swap(p1 in out number,p2 in out number)isv_temp number;beginv_temp:=p1;p1:=p2;p2:=v_temp;end;
調(diào)用帶IN OUT參數(shù)的過(guò)程:declarenum1 number:=100;num2 number:=200;beginswap(num1,num2);dbms_output.put_line('num1= '||num1);dbms_output.put_line('num2= '||num2);end;
示例4:將過(guò)程的執(zhí)行權(quán)限授予其他用戶GRANT EXECUTE ON find_emp TO scott;GRANT EXECUTE ON swap TO PUBLIC;將find_emp過(guò)程的執(zhí)行權(quán)限授予給用戶scott,將執(zhí)行swap過(guò)程的權(quán)限授予所有數(shù)據(jù)庫(kù)用戶。刪除過(guò)程語(yǔ)法:DROP PROCEDURE procudure_name;
2、函數(shù)定義函數(shù)的語(yǔ)法如下:CREATE [OR REPLACE] FUNCTION function_name[(parameter_list)]RETURN datatype{IS|AS}[local_declarations]BEGINexecutable_statements[EXCEPTIONexception_handlers]END [function_name];其中:function_name是函數(shù)的名稱。parameter_list是參數(shù)列表。local_declarations是局部聲明。executable_statements是可執(zhí)行語(yǔ)句。exception_handlers是異常處理程序。使用函數(shù)時(shí)注意:形式參數(shù)必須只使用數(shù)據(jù)庫(kù)類型,不得使用PL/SQL類型。函數(shù)的返回類型也必須是數(shù)據(jù)庫(kù)類型。函數(shù)不能單獨(dú)執(zhí)行,只能通過(guò)SQL語(yǔ)句或PL/SQL程序塊來(lái)調(diào)用。示例5:演示如何創(chuàng)建函數(shù)create or replace function fun_helloreturn varchar2 isbeginreturn '朋友,您好';end;調(diào)用函數(shù):select fun_hello from dual;
函數(shù)的授權(quán):同過(guò)和的授權(quán)一樣具體請(qǐng)看示例4。刪除函數(shù):DROP FUNCTION function_name
過(guò)程和函數(shù)的差異過(guò)程 函數(shù)作為PL/SQL語(yǔ)句執(zhí)行 作為表達(dá)式的一部分調(diào)用在規(guī)范中不包含RETURN子句 必須在規(guī)范中包含RETURN子句不返回任何值 必須返回單個(gè)值可以包含RETURN語(yǔ)句,但是與函數(shù)不同,它不能用于返回值 必須包含至少一條RETURN語(yǔ)句
3、程序包創(chuàng)建包規(guī)范的語(yǔ)法:CREATE [OR REPLACE] PACKAGE package_nameIS|AS[Public type and item declarations][Subprogram specifications]END [package_name];其中:package_name是包的名稱。Public type and item declarations是聲明類型、常量、變量、異常和游標(biāo)等。Subprogram specifications聲明PL/SQL子程序。示例6:演示創(chuàng)建程序包規(guī)范create or replace package pack_op isprocedure pro_print_ename(id number);procedure pro_print_sal(id number);function fun_re_date(id number) return date;end;
創(chuàng)建包主體的語(yǔ)法:CREATE [OR REPLACE] PACKAGE BODY package_nameIS|AS[Public type and item declarations][Subprogram bodies][BEGINInitialization_statements]END [package_name];其中:package_name是包的名稱。Public type and item declarations是聲明類型、常量、變量、異常和游標(biāo)等。Subprogram bodies是定義公共和私有PL/SQL子程序。
示例7:演示創(chuàng)建程序包主體create or replace package body pack_op isprocedure pro_print_ename(id number) isname emp.ename%type;beginselect ename into name from emp where empno=id;dbms_output.put_line('職員姓名:'||name);end pro_print_ename;procedure pro_print_sal(id number) issalary emp.sal%type;beginselect sal into salary from emp where empno=id;dbms_output.put_line('職員工資:'||salary);end pro_print_sal;function fun_re_date(id number) return date isbedate emp.hiredate%type;beginselect hiredate into bedate from emp where empno=id;return bedate;end fun_re_date;end pack_op;
示例8:調(diào)用程序包中創(chuàng)建的過(guò)程和函數(shù)exec pack_op.pro_print_ename(7900);exec pack_op.pro_print_sal(7900);select pack_op.fun_re_date(7900) from dual;
示例9:演示程序包中的游標(biāo)創(chuàng)建包規(guī)范create or replace package pack_emp iscursor cur_emp return emp%rowtype;procedure pro_cur;end pack_emp;
創(chuàng)建包主體create or replace package body pack_emp iscursor cur_emp return emp%rowtype isselect * from emp;procedure pro_cur isrec_emp emp%rowtype;beginopen cur_emp;loopfetch cur_emp into rec_emp;exit when cur_emp%notfound;if rec_emp.sal<1000 thendbms_output.put_line('員工工資:'||rec_emp.sal||',需加倍努力爭(zhēng)取提高工資');elsif rec_emp.sal>=1000 and rec_emp.sal<2000 thendbms_output.put_line('員工工資:'||rec_emp.sal||',工資一般,爭(zhēng)取搞個(gè)部門經(jīng)理做做');elsedbms_output.put_line('員工工資:'||rec_emp.sal||',工資不錯(cuò),爭(zhēng)取搞個(gè)總經(jīng)理做做');end if;end loop;end pro_cur;end pack_emp;
調(diào)用程序包中的過(guò)程以調(diào)用程序包中的游標(biāo)exec pack_emp.pro_cur;
示例10:存儲(chǔ)過(guò)程返回游標(biāo)的子程序包(此程序包返回r_cur游標(biāo))CREATE OR REPLACE package SCOTT.pk_wtistype mytype is ref cursor;procedure p_wt(mycs out mytype);end;
CREATE OR REPLACE package BODY SCOTT.pk_wtisprocedure p_wt(mycs out mytype)isr_cur mytype;beginopen r_cur for select * from emp;mycs:=r_cur;end p_wt;end pk_wt;
查詢有關(guān)過(guò)程、函數(shù)和程序包的信息:USER_OBJECTS數(shù)據(jù)字典視圖column object_name format a18select object_name,object_type from user_objects where object_type in ('PROCEDURE','FUNCTION','PACKAGE','PACKAGE BODY');
注意事項(xiàng):
1, 存儲(chǔ)過(guò)程參數(shù)不帶取值范圍,in表示傳入(只能位于等號(hào)右邊),out表示輸出(只能位于等號(hào)左邊),in out表示該類型既能被賦值也能傳值;
類型可以使用任意Oracle中的合法類型。
2, 變量帶取值范圍,后面接分號(hào)
3, 在判斷語(yǔ)句前最好先用count(*)函數(shù)判斷是否存在該條操作記錄
4, 用select 。。。into。。。給變量賦值
5, 在代碼中拋異常用 raise+異常名
6, 用select時(shí),后面必須接into字段,在游標(biāo)和循環(huán)里面就另當(dāng)別論了
7,在package里,不能create or replace
8,不寫in,out,默認(rèn)為in
來(lái)自: 昵稱10504424 > 《Oracle》
0條評(píng)論
發(fā)表
請(qǐng)遵守用戶 評(píng)論公約
oracle 創(chuàng)建,刪除存儲(chǔ)過(guò)程,參數(shù)傳遞,創(chuàng)建,刪除存儲(chǔ)函數(shù),存儲(chǔ)過(guò)程和函數(shù)的查看,包,系統(tǒng)包
oracle 存儲(chǔ)過(guò)程 函數(shù) 創(chuàng)建 刪除 參數(shù) 傳遞 函數(shù) 查看 包 系統(tǒng)包
Oracle存儲(chǔ)過(guò)程
Oracle筆記 十三、PL/SQL面向?qū)ο笾畃ackage
in_emp_record emp2%rowtype,update emp2 set sal = in_emp_record.sal where deptno = in_emp_record.deptno;execute immediate temp_sql using in_emp_new_record.empno, in_emp_new_record.ename,in...
Oracle筆記-第5天
--定義變量的時(shí)候要指定長(zhǎng)度 v_job varchar2(20); begin --部門 for c1rec in c1 loop --參數(shù)在游標(biāo)中...
第10章PLSQL程序開發(fā)
v_ne w_job_id jobs.job_id%type;CREAT E OR REPLACE PROCEDURE proc_department_change( p_employee_id em ployees.employee_id%type, p_new_department_name departments.dep artment_name%type) AS ...
Oracle數(shù)據(jù)庫(kù)語(yǔ)句大全
修改表的命令alter table stu_table rename to stu_tbl;--修改表名alter table stu_tbl rename column stu_sex to sex;--修改列名alter table stu_tbl add (stu_age number);--添加新列alter table stu...
PL/SQL編程急速上手
PL/SQL編程急速上手。Oracle 官方提供了兩款開發(fā)工具:SQL*Plus 和 Oracle SQL Developer。前面提到,PL/SQL 是對(duì)標(biāo)準(zhǔn) SQL 的擴(kuò)展,所以,在 PL/SQL 中不僅可以執(zhí)行 SQL 語(yǔ)句,還支持很多增強(qiáng)的特性,...
存儲(chǔ)過(guò)程基礎(chǔ)語(yǔ)法解析
/二、IF語(yǔ)句三、CASE語(yǔ)句四、簡(jiǎn)單循環(huán)LOOP循環(huán):declarev_countint:=1;beginloopdbms_output.put_line(v_count);v_count:=v_count+1;exitwhenv_count>20;endloop;end;/while循環(huán):whilev_cunt+1;end...
oracle pl/sql基本語(yǔ)法
---pl/sql中的loop循環(huán)---用三種方式輸出1到10個(gè)數(shù)字---while循環(huán)declare i number(2) := 1;begin while i<11 loop dbms_output.put_line(i); i := i 1; end loop; end;---exit循環(huán)declare i number...
微信掃碼,在手機(jī)上查看選中內(nèi)容