当前位置: 首页 > news >正文

河源市seo网站设计c2c商城网站建设公司

河源市seo网站设计,c2c商城网站建设公司,网站建设周期规划,大学生简历模板Oracle Subprogram,即Oracle子程序,是Oracle数据库中存储的过程(Procedures)和函数(Functions)的统称。这些子程序是存储在数据库中的PL/SQL代码块,用于执行特定的任务或操作。下面详细介绍Orac…

Oracle Subprogram,即Oracle子程序,是Oracle数据库中存储的过程(Procedures)和函数(Functions)的统称。这些子程序是存储在数据库中的PL/SQL代码块,用于执行特定的任务或操作。下面详细介绍Oracle Subprogram的几个方面:

一、基本概念

  • 过程(Procedures):过程是一系列为了完成特定功能而编写的SQL和PL/SQL语句的集合。过程执行操作但不返回值。
  • 函数(Functions):函数也是一系列SQL和PL/SQL语句的集合,但它执行计算并返回一个值。

二、特点与优势

  • 存储性:子程序存储在数据库中,可以在多个应用程序或数据库会话中重用,减少了代码冗余。
  • 封装性:通过封装复杂的业务逻辑,子程序可以提高代码的可读性和可维护性。
  • 安全性:通过控制对子程序的访问权限,可以保护数据库的安全。

三、类型

  • 独立子程序:在模式级别创建,不依赖于其他包或对象。
  • 包子程序:在包(Package)内创建,与包的其他部分(如类型、变量、游标等)紧密相关。

四、结构与组成

Oracle子程序遵循PL/SQL块结构,通常由以下几个部分组成:

  1. 声明部分(Declarative Part):包含子程序所需的类型、常量、变量、游标、异常等的声明。
  2. 执行部分(Executable Part):包含执行操作的SQL和PL/SQL语句。
  3. 异常处理部分(Exception Handling Part):包含处理执行过程中可能出现的异常的代码。

五、创建与调用

  • 创建:使用CREATE OR REPLACE PROCEDURE(对于过程)或CREATE OR REPLACE FUNCTION(对于函数)语句来创建子程序。
  • 调用:在PL/SQL代码块、触发器、其他子程序或应用程序中,通过指定子程序的名称和必要的参数(如果有)来调用子程序。

六、示例

6.1 以下是一个简单的Oracle过程示例,用于向表中插入一行数据:
CREATE OR REPLACE PROCEDURE AddEmployee(p_employee_id IN NUMBER,p_employee_name IN VARCHAR2,p_hire_date IN DATE
) AS
BEGININSERT INTO employees (employee_id, employee_name, hire_date)VALUES (p_employee_id, p_employee_name, p_hire_date);COMMIT;
EXCEPTIONWHEN OTHERS THENROLLBACK;RAISE_APPLICATION_ERROR(-20001, 'An error occurred while inserting employee.');
END AddEmployee;

在这个示例中,AddEmployee过程接受三个参数:员工ID(p_employee_id)、员工姓名(p_employee_name)和雇佣日期(p_hire_date)。它执行一个INSERT语句将数据插入到employees表中,并在成功插入后提交事务。如果在插入过程中发生任何异常,它将回滚事务并抛出一个应用程序错误。

6.2 声明、定义和调用简单的PL/SQL过程

Declaring, Defining, and Invoking a Simple PL/SQL Procedure

In this example, an anonymous block simultaneously declares and defines a procedure and invokes it three times. The third invocation raises the exception that the exception-handling part of the procedure handles.

DECLAREfirst_name employees.first_name%TYPE;last_name  employees.last_name%TYPE;email      employees.email%TYPE;employer   VARCHAR2(8) := 'AcmeCorp';-- Declare and define procedurePROCEDURE create_email (  -- Subprogram heading beginsname1   VARCHAR2,name2   VARCHAR2,company VARCHAR2)                         -- Subprogram heading endsIS-- Declarative part beginserror_message VARCHAR2(30) := 'Email address is too long.';BEGIN                     -- Executable part beginsemail := name1 || '.' || name2 || '@' || company;EXCEPTION                      -- Exception-handling part beginsWHEN VALUE_ERROR THENDBMS_OUTPUT.PUT_LINE(error_message);END create_email;BEGINfirst_name := 'John';last_name  := 'Doe';create_email(first_name, last_name, employer);  -- invocationDBMS_OUTPUT.PUT_LINE ('With first name first, email is: ' || email);create_email(last_name, first_name, employer);  -- invocationDBMS_OUTPUT.PUT_LINE ('With last name first, email is: ' || email);first_name := 'Elizabeth';last_name  := 'MacDonald';create_email(first_name, last_name, employer);  -- invocation
END;
/

Result:

With first name first, email is: John.Doe@AcmeCorp
With last name first, email is: Doe.John@AcmeCorp
Email address is too long.PL/SQL procedure successfully completed.
6.3 声明、定义和调用简单的PL/SQL函数

Declaring, Defining, and Invoking a Simple PL/SQL Function
In this example, an anonymous block simultaneously declares and defines a function and invokes it.

DECLARE-- Declare and define functionFUNCTION square (original NUMBER)   -- parameter listRETURN NUMBER                     -- RETURN clauseAS-- Declarative part beginsoriginal_squared NUMBER;BEGIN                               -- Executable part beginsoriginal_squared := original * original;RETURN original_squared;          -- RETURN statementEND;
BEGINDBMS_OUTPUT.PUT_LINE(square(100));  -- invocation
END;
/
-- Result
10000PL/SQL procedure successfully completed.
6.4 函数中RETURN语句后恢复执行

Execution Resumes After RETURN Statement in Function

DECLAREx INTEGER;FUNCTION f (n INTEGER)RETURN INTEGERISBEGINRETURN (n*n);END;BEGINDBMS_OUTPUT.PUT_LINE ('f returns ' || f(2) || '. Execution returns here (1).');x := f(2);DBMS_OUTPUT.PUT_LINE('Execution returns here (2).'|| f(x));
END;
/
-- Result
f returns 4. Execution returns here (1).
Execution returns here (2).16PL/SQL procedure successfully completed.
6.5 每个执行路径都指向RETURN语句的函数

Function Where Every Execution Path Leads to RETURN Statement

CREATE OR REPLACE FUNCTION f (n INTEGER)RETURN INTEGERAUTHID DEFINER
IS
BEGINIF n = 0 THENRETURN 1;ELSIF n = 1 THENRETURN n;ELSERETURN n*n;END IF;
END;
/
BEGINFOR i IN 0 .. 3 LOOPDBMS_OUTPUT.PUT_LINE('f(' || i || ') = ' || f(i));END LOOP;
END;
/
-- Result
f(0) = 1
f(1) = 1
f(2) = 4
f(3) = 9PL/SQL procedure successfully completed.
6.6 程序中返回声明后恢复执行

Execution Resumes After RETURN Statement in Procedure

DECLAREPROCEDURE p ISBEGINDBMS_OUTPUT.PUT_LINE('Inside p');RETURN;DBMS_OUTPUT.PUT_LINE('Unreachable statement.');END;
BEGINp;DBMS_OUTPUT.PUT_LINE('Control returns here.');
END;
/
-- Result
Inside p
Control returns here.PL/SQL procedure successfully completed.
6.7 形式参数和实际参数

Formal Parameters and Actual Parameters

DECLAREemp_num NUMBER(6) := 120;bonus   NUMBER(6) := 100;merit   NUMBER(4) := 50;PROCEDURE raise_salary (emp_id NUMBER,  -- formal parameteramount NUMBER   -- formal parameter) ISBEGINUPDATE employeesSET salary = salary + amount  -- reference to formal parameterWHERE employee_id = emp_id;   -- reference to formal parameterEND raise_salary;BEGINraise_salary(emp_num, bonus);          -- actual parameters/* raise_salary runs this statement:UPDATE employeesSET salary = salary + 100WHERE employee_id = 120;       */raise_salary(emp_num, merit + bonus);  -- actual parameters/* raise_salary runs this statement:UPDATE employeesSET salary = salary + 150WHERE employee_id = 120;       */
END;
/
6.8 实际参数和返回值仅继承子类型的范围

Actual Parameter and Return Value Inherit Only Range From Subtype

DECLAREFUNCTION test (p INTEGER) RETURN INTEGER ISBEGINDBMS_OUTPUT.PUT_LINE('p = ' || p);RETURN p;END test;BEGINDBMS_OUTPUT.PUT_LINE('test(p) = ' || test(0.66));
END;
/
-- Result
p = .66
test(p) = .66PL/SQL procedure successfully completed.
6.9 函数隐式地将形式参数转换为受约束的子类型

Function Implicitly Converts Formal Parameter to Constrained Subtype

DECLAREFUNCTION test (p NUMBER) RETURN NUMBER ISq INTEGER := p;  -- Implicitly converts p to INTEGERBEGINDBMS_OUTPUT.PUT_LINE('p = ' || q);  -- Display q, not pRETURN q;                           -- Return q, not pEND test;BEGINDBMS_OUTPUT.PUT_LINE('test(p) = ' || test(0.66));
END;
/
-- Result
p = 1
test(p) = 1PL/SQL procedure successfully completed.

七、总结

Oracle Subprogram是Oracle数据库中强大的编程结构,它们通过封装复杂的业务逻辑、提高代码重用性和维护性,在数据库应用程序开发中发挥着重要作用。

http://www.yayakq.cn/news/189605/

相关文章:

  • 阜宁做网站哪家最好西安网络推广外包公司
  • 网站建设兆金手指科杰平顶山车祸最新新闻事件
  • 嘉兴制作网站软件长泰微新闻
  • 快站淘客小程序开发定制北京公司
  • 建设网站商城国外点击链接推广平台
  • 企顺网网站建设做红木家具推广哪个网站比较好
  • 最成功的个人网站最火爆的网页游戏
  • 广州企业推广网站建设dede网站地图xml
  • 建站知识怎么制作网页教程步骤
  • 长春网站制作推广做网站怎么自定义背景图片
  • 怎么做盗版电影网站企业门户网站建设行情
  • 网站图表怎么做的做网站参考文献
  • 网站建设 wordpress系统越南注册公司需要什么条件
  • 官方网站平台下载大数据营销案例分析
  • 安庆专业做淘宝网站手机上page转换wordpress
  • 网站升级建设费用现在房地产的最新情况
  • 深圳深圳做网站怎么用自己的电脑做网站空间
  • iis 与 wordpress西安专业seo
  • 长安网站建设网络推广工业信息化部网站备案
  • 网站运营 流程360官网首页入口
  • 注册一个网站英迈寰球网站建设
  • 北京网站开发浩森宇特网站免费优化工具
  • p2p网站建设源码网站首页图片做多大
  • 无锡新区企业网站推广wordpress搬家
  • 一元夺宝网站怎么做天津通用网站建设收费
  • 网站集约建设原因榆林 网站建设
  • 蓬莱做网站那家好西部虚拟主机网站后台不能访问
  • dw网站根目录怎么做学做会计账的网站
  • 网站维护外包方案长沙网站设计
  • 富民网站建设微信发布wordpress