PL/SQL过程

 

子程序是一个程序单元/模块执行特定的任务。这些子程序被组合以形成更大的程序。这基本上是被称为“模块化设计”。子程序可以调用由另一个子程序或程序被称为调用程序。

子程序可以创建:

  • 在模式层面

  • 在包里面

  • 在一个PL/SQL块内

模式级子程序是一个独立的子程序。它使用CREATE PROCEDURE或CREATE FUNCTION语句创建。它被存储在数据库中,并且可以使用DROP PROCEDURE或DROP FUNCTION语句被删除。

一个包内创建的一个子程序是一个封装子程序。它被存储在数据库中,仅当包被删除使用DROP PACKAGE语句可以被删除。我们将讨论在"PL/SQL - 包“ 章节中。

PL/SQL子程序被命名,可使用一组参数来调用PL/SQL块。 PL/SQL提供两种子程序:

  • 函数:这些子程序返回一个值,主要用于计算并返回一个值。

  • 过程:这些子程序没有直接返回值,主要用于执行操作。

本章将重点介绍PL/SQL的过程的重内容,我们将在下一章介绍学习"PL/SQL函数“。

PL/SQL子程序部分

每个PL/SQL子程序有一个名称,并且可以具有一个参数列表。就像匿名PL/SQL块,并命名块子程序也将有以下三个部分:

S.N. 部分 & 描述
1 声明部分
它是一个任选的组成部分。然而声明部分用于子程序并在开始时使用DECLARE关键字。它包含:类型,光标,常量,变量,异常和嵌套子程序声明。这些项局部于子程序和停止时,子程序完成执行完成前存在。
2 执行部分
这是一个强制性的一部分,包含执行指定操作语句
3 异常处理部分
这也是一个可选部分,它包含处理运行时错误的代码。

创建过程

过程使用CREATE OR REPLACE PROCEDURE语句创建,使用CREATE OR REPLACE PROCEDURE语句简化语法如下:

CREATE [OR REPLACE] PROCEDURE procedure_name
[(parameter_name [IN | OUT | IN OUT] type [, ...])]
{IS | AS}
BEGIN
< procedure_body >
END procedure_name;

这里,

  • procedure-name 指定的程序的名称

  • [OR REPLACE] 选项允许修改现有的程序

  • 可选的参数列表中包含的名称,模式和类型的参数。IN表示该值将被从外部传递,OUT表示该参数将被用于从过程返回一个值到外面

  • procedure-body 包含可执行部分

  • AS关键字来代替了IS关键字用于创建一个独立的程序。

例子:

下面的示例创建一个字符串的简单过程执行时将'Hello World!“显示在屏幕上。

CREATE OR REPLACE PROCEDURE greetings
AS
BEGIN
dbms_output.put_line('Hello World!');
END;
/

当上面的代码中使用SQL提示执行,它会产生以下结果:

Procedure created.

执行独立程序

一个独立的程序可以有两种方式调用:

  • 使用EXECUTE关键字

  • 从PL/SQL块调用过程的名称

名为“greetings”的上述程序可以调用EXECUTE关键字为:

EXECUTE greetings;

上述调用会显示:

Hello World

PL/SQL procedure successfully completed.

程序也可以从另一个PL/SQL块调用:

BEGIN
greetings;
END;
/

上述调用会显示:

Hello World

PL/SQL procedure successfully completed.

删除独立程序

一个独立的程序使用DROP PROCEDURE语句删除。删除一个程序的语法是:

DROP PROCEDURE procedure-name;

所以,可以使用下面的语句删除 greetings 

BEGIN
DROP PROCEDURE greetings;
END;
/

PL/SQL子程序参数模式

S.N. 参数模式 & 描述
1 IN
一个IN参数传递一个值到子程序。它是一个只读的参数。内部的子程序,一个IN参数的作用就像一个常数。它不能再被分配值。 可以通过一个常量,文字,初始化变量或表达式作为一个IN参数。也可以把它初始化为默认值;然而,在这种情况下,它从子程序调用删去。这就是参数传递的默认模式。参数是通过引用传递。
2 OUT
OUT参数返回一个值到调用程序。在内部的子程序OUT参数就像一个变量。可以改变它的值并引用分配后的值。实际参数必须是变量,它是按值传递。
2 IN OUT
一个IN OUT参数传递的初始值到一个子程序,并返回一个更新值给调用者。它可以被分配一个值,其值可被读取。
对应一个IN OUT形式参数的实际参数必须是一个变量,不是常量或表达式。形参必须分配一个值。实际参数就是按值传递。

IN & OUT 模式示例 1

该程序查找两个值中的最小值,这里过程使用IN模式接收两个数字,并使用OUT参数返回它们的最小值。

DECLARE
a number;
b number;
c number; PROCEDURE findMin(x IN number, y IN number, z OUT number) IS
BEGIN
IF x < y THEN
z:= x;
ELSE
z:= y;
END IF;
END; BEGIN
a:= 23;
b:= 45;
findMin(a, b, c);
dbms_output.put_line(' Minimum of (23, 45) : ' || c);
END;
/

当上述代码在SQL提示符执行时,它产生了以下结果:

 Minimum of (23, 45) : 23

PL/SQL procedure successfully completed.

IN & OUT 模式示例2

这个程序计算传递值的平方值。这个例子表明我们如何能够用相同的参数接受的值,然后返回另一个结果。

DECLARE
a number;
PROCEDURE squareNum(x IN OUT number) IS
BEGIN
x := x * x;
END;
BEGIN
a:= 23;
squareNum(a);
dbms_output.put_line(' Square of (23): ' || a);
END;
/

当上述代码在SQL提示符执行时,它产生了以下结果:

Square of (23): 529

PL/SQL procedure successfully completed.

方法传递参数

实际参数可以通过以下三种方式:

  • 位置标记

  • 命名符号

  • 混合符号

位置表示法

在位置符号,可以调用的程序为:

findMin(a, b, c, d);

在位置表示法中,第一实际参数代入所述第一形式参数;第二实际参数代入所述第二形式参数,依此类推。那么,a取代x,b是取代为y,c为取代z以及d被代替m。

命名表示法

名为符号,实际参数与使用箭头符号的形式参数相关的(=>)。所以程序调用将如下所示:

findMin(x=>a, y=>b, z=>c, m=>d);

混合表示法

在混合符号表示法中,可以混合这两种写法过程调用;但是,位置标记应先于指定符号。

下面的调用是合法的:

findMin(a, b, c, m=>d);

但是,这样是不合法的:

findMin(x=>a, b, c, d);

SQL记录-PLSQL过程的更多相关文章

  1. SQL记录-PLSQL函数

    PL/SQL函数 PL/SQL函数与过程相同,不同之处在于函数有一个返回值.因此,前面的章节中的所有讨论都适用于函数. 创建函数 建立一个独立函数可以使用CREATE FUNCTION语句创建.CRE ...

  2. SQL记录-PLSQL记录

    PL/SQL记录   PL/SQL记录就是可以容纳不同类型的数据项的数据结构.记录由不同字段,类似于数据库表的行. 例如,要保留跟踪图书馆中的书籍.可能要跟踪有关每本书下面的属性类似:标题,作者,主题 ...

  3. SQL记录-PLSQL基本语法与数据类型

    PL/SQL基本语法 PL/SQL是一种块结构的语言,这意味着PL/SQL程序被划分和编写代码的逻辑块.每块由三个子部分组成: S.N. 段和说明 1 声明 此部分开头使用关键字DECLARE.它是一 ...

  4. SQL记录-PLSQL包

    PL/SQL包 PL/SQL包是组逻辑相关的PL/SQL类型,变量和子程序模式对象. 程序包将有两个强制性的部分: 包装规范定义 包体或定义 包装规范定义 规范是接口到包.它只是声明的类型,变量,常量 ...

  5. SQL记录-PLSQL游标

    PL/SQL游标 Oracle会创建一个存储区域,被称为上下文区域,用于处理SQL语句,其中包含需要处理的语句,例如所有的信息,行数处理,等等. 游标是指向这一上下文的区域. PL/SQL通过控制光标 ...

  6. SQL记录-PLSQL循环

    PL/SQL循环   可能有一种情况,当需要执行的代码块的几个多次.在一般情况下,语句顺序执行:一个函数的第一条语句,首先执行,然后是第二个...等等. 编程语言提供了各种控制结构,允许更多复杂的执行 ...

  7. SQL记录-PLSQL条件控制

    PL/SQL条件控制   决策结构需要程序员指定一个或多个条件要计算,或由程序进行测试,如果条件被确定为真那么一条或多条语句被执行,如果要被执行的其它语句条件被确定为假,则选其它执行块. 以下是从在大 ...

  8. SQL记录-PLSQL变量与常量文字

    PL/SQL变量   变量是只不过是一个给定的存储区域,程序可以操纵的名称.PL/SQL每个变量具有一个特定的数据类型,它决定了大小和变量的存储器的值,可以说存储器和设置操作可以施加到可变内被存储的范 ...

  9. SQL记录-PLSQL触发器

    PL/SQL触发器 触发器是存储程序,它会自动执行或发射当一些事件发生.触发器,事实上,写入响应于以下任一事件将被执行: 数据库操作(DML)语句(DELETE,INSERT,UPDATE或) 数据库 ...

随机推荐

  1. django在admin后台注册自己创建的数据库表

    django在admin后台注册自己创建的数据库表,这样我们就可以在admin后台看到表结构信息,我们就可以在admin后台快速录入表记录信息 如果没有注册,那么你在登录django自带的admin的 ...

  2. 使用不同的方法计算TF-IDF值

    摘要 这篇文章主要介绍了计算TF-IDF的不同方法实现,主要有三种方法: 用gensim库来计算tfidf值 用sklearn库来计算tfidf值 用python手动实现tfidf的计算 总结 之所以 ...

  3. 在git与tortoisegit中使用openSSH与PuTTY

    问题 在使用Git与tortoisegit的时候,指定远程版本库的地址有2种方式: 使用https方式的git地址非常直接(https://xxx.oschina.net/xxx.git),基本上什么 ...

  4. HTML表单与输入实例

    解释HTML 表单用于搜集不同类型的用户输入.HTML 表单包含表单元素.表单元素指的是不同类型的 input 元素.复选框.单选按钮.提交按钮等等.<input> 元素<input ...

  5. BugkuCTF web2

    前言 写了这么久的web题,算是把它基础部分都刷完了一遍,以下的几天将持续更新BugkuCTF WEB部分的题解,为了不影响阅读,所以每道题的题解都以单独一篇文章的形式发表,感谢大家一直以来的支持和理 ...

  6. 教你用PS制作雨天窗户上透明水滴字

    雨天窗户上透明水滴字制作方法很简单,主要利用图层样式来实现.学习后可以让你对图层样式有更好的了解,认识. 先看下完成后的效果图: 步骤1: 在Photoshop中我们新建或Ctrl+N,创建1920x ...

  7. LeetCode 606. Construct String from Binary Tree根据二叉树创建字符串 (C++)

    题目: You need to construct a string consists of parenthesis and integers from a binary tree with the ...

  8. java入门--4110:圣诞老人的礼物-Santa Clau’s Gifts

    学习了一下java的语法,就用poj上的题目做作练习,好更快的熟悉常用的java语法. 题目在这里 http://bailian.openjudge.cn/practice/4110/ import ...

  9. 2017-8-20 HTTP协议

    http协议 http协议是一种超文本传输协议(一种约定) 三大特性:无状态,媒体独立,无连接: HTTP 工作原理 HTTP协议工作于客户端-服务端架构为上.浏览器作为HTTP客户端通过URL向HT ...

  10. Linux dd命令制作U盘启动盘

    linux下的dd命令来自于coreutils:http://www.gnu.org/software/coreutils/ https://jingyan.baidu.com/article/d45 ...