c#调用oracle存储过程

上传人:人*** 文档编号:501015477 上传时间:2023-07-14 格式:DOCX 页数:10 大小:17.83KB
返回 下载 相关 举报
c#调用oracle存储过程_第1页
第1页 / 共10页
c#调用oracle存储过程_第2页
第2页 / 共10页
c#调用oracle存储过程_第3页
第3页 / 共10页
c#调用oracle存储过程_第4页
第4页 / 共10页
c#调用oracle存储过程_第5页
第5页 / 共10页
点击查看更多>>
资源描述

《c#调用oracle存储过程》由会员分享,可在线阅读,更多相关《c#调用oracle存储过程(10页珍藏版)》请在金锄头文库上搜索。

1、精品文档,仅供学习与交流,如有侵权请联系网站删除子程序 是已经命名的PLSQL块,他们存储在数据库中,可以为他们指定参数,可以在客户端和应用程序中调用它们。子程序包括 存储过程 和 函数,程序包 是存储过程和 函数的集合。存储过程-语法:CREATE OR REPLACE PROCEDURE procedure_name(parameter_list)IS|ASlocal_declarationsBEGINexecutable_statementsEXCEPTIONexception_handlersEND procedure_name;语法说明:procedure_name 是过程名字par

2、ameter_list 是参数列表local_declarations 是局部声明executable_statements 是可执行语句,execption_handlers是 异常处理程序-create or replace procedure wyd_print(times number)is i number :=0;beginloopi :=i+1;DBMS_OUTPUT.PUT_LINE(第|i|次 循环!);exit when i= times;end loop;end;/直接调用存储过程:exec wyd_print(20)execute wyd_print(30);过程参数模

3、式调用程序是通过参数向被调用的过程传递值的。参数传递的模式有3种:IN ,OUT ,IN OUT 。也就是输入,输出,输入 输出定义过程参数的语法:parameter_name IN |OUT |IN OUT datatype :=| DEFAULT expression参数IN模式 是默认模式如果要指定OUT | IN OUT 模式参数 要 明确指定-实例:CREATE OR REPLACE PROCEDURE mypar(a IN number,b OUT number,c IN OUT number)ISBEGINDBMS_OUTPUT.PUT_LINE(a -|a);DBMS_OUTP

4、UT.PUT_LINE(b -|b);DBMS_OUTPUT.PUT_LINE(c -|c);-a:=111;b:=222;c:=333;DBMS_OUTPUT.PUT_LINE(a -|a);DBMS_OUTPUT.PUT_LINE(b -|b);DBMS_OUTPUT.PUT_LINE(c -|c);END mypar;/-declareaa number:=11;bb number:=22;cc number:=33;beginDBMS_OUTPUT.PUT_LINE(before aa -|aa);DBMS_OUTPUT.PUT_LINE(before bb -|bb);DBMS_OU

5、TPUT.PUT_LINE(before cc -|cc);mypar(aa,88,cc);DBMS_OUTPUT.PUT_LINE(after aa -|aa);DBMS_OUTPUT.PUT_LINE(after bb -|bb);DBMS_OUTPUT.PUT_LINE(after cc -|cc);end;/注意几点:(1)IN类型参数 在 过程中不能 再给赋值(2)OUT INOUT 类型 可以进入后赋值。(3)OUT 类型参数在调用过程传入参数时无效,(4)OUT ,IN OUT 类型参数 在调用过程时传入的必须是变量-一个过程创建了,将执行权限授予其他用户语法:GRANT EXE

6、CUTE ON procedure_name TO USER_Name; /授权给特定用户执行过程的权限GRANT EXECUTE ON procedure_name TO public ; /授权给所有数据库用户执行过程的权限查看数据库里面的存储过程:select object_name from user_objects where object_type=PROCEDURE;select substr(object_name,1,20) object_name,object_type from user_objects where object_type=PROCEDURE;select

7、 substr(object_name,1,10) object_name,object_type from user_objects;删除一个过程:DROP procedure procedure_name;_ 函数的 定义 和 使用 _函数与过程相似,也是数据库中存储的已经命名的PL/SQL块。函数的主要特性:(1)必须有一个返回值(2)函数不能单独执行,只能通过SQL语句 或者PL/SQL程序块来调用。函数定义 - 语法:CREATE OR REPLACE FUNCTION function_name(parameter1,parameter2.)RETURN datatypeIS|AS

8、local_declarationsBEGINExexutable_Statements;EXCEPTIONException_handlers;END;/注意:(1)函数只能带有 IN 参数,而不能带有 IN OUT 或 OUT 参数。(2)形式参数必须只能使用数据库类型,不能使用PL/SQL类型。(3)函数返回类型也必须是数据库类型。-创建一个函数:create or replace function fun_sum(a number,b number)return numberISBEGINreturn a+b;END;通过SQL来执行函数:SELECT function_name(pa

9、rameter1,parameter2.) FROM DUAL;select fun_sum(5,6) from dual;查看数据库里面的用户创建的函数:select object_name from user_objects where object_type=FUNCTION;select substr(object_name,1,20) object_name,object_type from user_objects where object_type=FUNCTION;-函数的授权:GRANT EXECUTE ON function_name TO USER_Name; /函数的使

10、用权授予特定的用户GRANT EXECUTE ON function_name TO public; /函数的使用权授予数据库中所有用户example:GRANT EXECUTE ON fun_sum to public;* 自主事务处理自主事务处理 是有另一个事务处理(主事务处理) 启动的独立事务处理。举例:/P1就是 自主事务处理CREATE OR REPLACE PROCEDURE p1 ASPRAGMA AUTONOMOUS_TRANSACTION; -就这句话,让事务处理独立开来了BEGINEND p1;/CREATE OR REPLACE PROCEDURE p2ASBEGIN.p

11、1;.END p2;/p2 过程 调用 了P1 过程,但是 p1过程声明了事务独立,使得p1的运行对p2没有直接影响。删除一个函数:语法:DROP FUNCTION Function_name;Example:drop FUNCTION fun_sum;-* 程序包 的创建 和使用 *-程序包是一种数据库对象,它是对相关PL/SQL类型,子程序,游标,异常,变量和常量的封装。创建一个程序包 有两个步骤:(1) 创建 程序包规范。(也可以说成是 声明程序包)基本语法:CREATE OR PEPLACE PACKAGE package_nameIS|ASpublic type and item d

12、eclarationssubprogram specificationsEND package_name; /-(2) 创建 程序包主体。(也可以说成是实现程序包)基本语法:CREATE OR REPLACE PACKAGE BODY package_nameIS|ASPublic type and item declarationsSubprogram bodiesBEGIN Initialization_statementsEND package_name;package_namePublic type and item declarations 声明变量,常量,游标,异常 或者 类型。S

13、ubprogram bodies 定义公共和私有PL/SQL子程序-实际例子:(1)创建程序包规范:CREATE OR REPLACE PACKAGE wyd_packageISPROCEDURE wyd_print(name varchar2);FUNCTION wyd_sum(a number,b number) return number;END wyd_package;(2)创建程序包主体:CREATE OR REPLACE PACKAGE BODY wyd_packageAS-实现wyd_print 存储过程PROCEDURE wyd_print(name varchar2) ISBEGINDBMS_OUTPUT.PUT_LINE(Hello,|name);END wyd_print;-实现wyd_sum 函数FUNCTION wyd_sum(a number,b number) RETURN NUMBERISBEGINreturn

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 中学教育 > 试题/考题 > 初中试题/考题

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号