1.语法

create [or replace] procedure pro_name[(parameter1,parameter2,...)] is|as
begin
plsql_sentences;
[exception]
[dowith_sentences;]
end pro_name;

参数说明:

pro_name:存储过程名称

parameter1:参数

plsql_sentences:PL/SQL语句,它是存储过程功能实现的主体。

dowith_sentences:异常处理语句,也是PL/SQL语句。

上面的parameter1指的是存储过程被调用时候用的参数,内部变量需要在is|as关键字后边定义,并使用;号结束

2.环境准备

2.1 创建表TMP001

字段 描述 类型
id 客户编号 int
name 客户名称 varchar2(100)
gender 客户性别 varchar2(2)
age 客户年龄 int
address 客户地址 varchar2(200)

脚本:

create table TMP001(
id int not null,
name varchar2(100),
gender varchar2(2),
age int,
address varchar2(200)
)

3.具体案例

3.1创建一个简单存储过程,往表TMP001插入一条记录

/********************************************************
功能名称:用于简单存储过程测试
用途 :插入一条记录到TMP001表中 参数列表
---------------------------------------------------------
参数 IN/OUT 类型 描述
---------------------------------------------------------

--------------------------------------------------------- 版本号:1.0
---------------------------------------------------------
作者:Qinys
日期:20180915
说明:创建
---------------------------------------------------------
---------------------------------------------------------
********************************************************/
create or replace procedure proInsertTmp001 is
begin
insert into TMP001 values(1,'张三','男',29,'云南省昆明市');
commit;
dbms_output.put_line('插入记录成功!');
end proInsertTmp001;

上述存储过程放在PL/SQL Developer中编译通过后,即可调用查看结果

调用存储过程

①execute命令调用:execute  proInsertTmp001

②使用PL/SQL块

begin

  proInsertTmp001;

end;

3.2声明一个带IN模式的存储过程

/**********************************************************************
功能名称:用于测试带IN的存储过程
用途 :插入一条记录到TMP001表中 参数列表
参数列表
-----------------------------------------------------------------------
参数 IN/OUT 类型 描述
-----------------------------------------------------------------------
int_id IN INT 客户编号
var_name IN VARCHAR2 客户名称
var_gender IN VARCHAR2 客户性别
int_age IN INT 客户年龄
var_address IN VARCHAR2 客户地址
----------------------------------------------------------------------- 版本号:1.0
-----------------------------------------------------------------------
作者:Qinys
日期:20180915
说明:创建
-----------------------------------------------------------------------
-----------------------------------------------------------------------
**********************************************************************/
create or replace procedure proInsertTmp002(
int_id in int,
var_name in varchar2,
var_gender in varchar2,
int_age in int,
var_address in varchar2
) is
begin
insert into TMP001 values(int_id,var_name,var_gender,int_age,var_address);
commit;
dbms_output.put_line('插入记录成功!');
end proInsertTmp002;

调用存储过程

查看结果

3.3 声明一个带OUT模式的存储过程

/**********************************************************************
功能名称:用于测试带OUT的存储过程
用途 :调用存储过程,并返回调用结果 参数列表
-----------------------------------------------------------------------
参数 IN/OUT 类型 描述
-----------------------------------------------------------------------
int_id IN INT 客户编号
var_name IN VARCHAR2 客户名称
var_gender IN VARCHAR2 客户性别
int_age IN INT 客户年龄 默认值为:18
var_address IN VARCHAR2 客户地址 默认值为:China
flag OUT VARCHAR2 1-成功 0-失败
msg OUT VARCHAR2 返回错误代码
----------------------------------------------------------------------- 版本号:1.0
-----------------------------------------------------------------------
作者:Qinys
日期:20180915
说明:创建
-----------------------------------------------------------------------
-----------------------------------------------------------------------
**********************************************************************/
create or replace procedure proInsertTmp004(
int_id in int,
var_name in varchar2,
var_gender in varchar2,
int_age in int default 18,
var_address in varchar2 default 'China',
flag out varchar2,
msg out varchar2
) is
begin
proInsertTmp003(int_id,var_name,var_gender,int_age,var_address);
commit;
--主体程序运行完毕
flag :='1';
--异常处理
exception
when others then
rollback;
flag :=0;
msg :='错误原因'|| sqlcode || ',' || sqlerrm(sqlcode);
end proInsertTmp004;

我们正常调用存储过程proInsertTmp004

在output可以看到结果

非正常调用

output结果

3.4 声明一个带OUT模式的存储过程

/**********************************************************************
功能名称:根据flag标志,若为True,则返回平方,反之,则返回平方根
用途 : 用于测试IN OUT参数的存储过程 参数列表
-----------------------------------------------------------------------
参数 IN/OUT 类型 描述
-----------------------------------------------------------------------
num IN OUT NUMBER 输入的值
flag IN boolean 只有True与False两种类型
----------------------------------------------------------------------- 版本号:1.0
-----------------------------------------------------------------------
作者:Qinys
日期:20180915
说明:创建
-----------------------------------------------------------------------
-----------------------------------------------------------------------
**********************************************************************/
create or replace procedure pro_square(
num in out number,
flag in boolean) is i int :=2;
begin
if flag then
num:=power(num,i);
else
num:=sqrt(num);
end if;
end pro_square;

调度存储过程

declare
var_temp number;
var_num number;
bool_flag boolean;
begin
var_temp := 4;
var_num := var_temp;
bool_flag := false;
pro_square(var_num,bool_flag);
if bool_flag then
dbms_output.put_line(var_temp||'的平方是:'||var_num);
else
dbms_output.put_line(var_temp||'的平方根是:'||var_num);
end if;
end;

调度结果是:

3.5 创建带有默认值的存储过程

/**********************************************************************
功能名称:用于测试带默认值的存储过程
用途 :插入一条记录到TMP001表中 参数列表
-----------------------------------------------------------------------
参数 IN/OUT 类型 描述
-----------------------------------------------------------------------
int_id IN INT 客户编号
var_name IN VARCHAR2 客户名称
var_gender IN VARCHAR2 客户性别
int_age IN INT 客户年龄 默认值为:18
var_address IN VARCHAR2 客户地址 默认值为:China
----------------------------------------------------------------------- 版本号:1.0
-----------------------------------------------------------------------
作者:Qinys
日期:20180915
说明:创建
-----------------------------------------------------------------------
-----------------------------------------------------------------------
**********************************************************************/
create or replace procedure proInsertTmp003(
int_id in int,
var_name in varchar2,
var_gender in varchar2,
int_age in int default 18,
var_address in varchar2 default 'China'
) is
begin
insert into TMP001 values(int_id,var_name,var_gender,int_age,var_address);
commit;
dbms_output.put_line('插入记录成功!');
end proInsertTmp003;

调用存储过程

此处指传入前三个参数

4.存储过程调用传递参数

4.1使用指定名称传递的方式传递参数

4.1.1 语法

pro_name(parameter1=>value1[,parameter1=>value1]…)

4.1.2 例子

我们从数据库的得知,确实已经插入,并且字段顺序没变

4.2使用按位置的方式传递参数

4.2.1 语法

此种传递是我们最常用的,也就是值与参数一一对应

4.2.2 例子

见具体案例3.2中的调用存储过程

4.3使用按位置的方式传递参数

4.3.1 语法

上述两种传递方式混合起来,但是在某个位置使用“指定名称传递”之后,后边的参数值必须使用指定名称传递,因为参数的原始定义顺序可能已经被破坏

4.3.2 例子

【Oracle】存储过程之完整篇的更多相关文章

  1. Oracle 存储过程学习

    转自:http://blog.chinaunix.net/uid-20495387-id-174394.html http://www.cnblogs.com/rootq/articles/11000 ...

  2. Oracle存储过程知识汇总

    基本语法篇: CREATE OR REPLACE PROCEDURE 存储过程名 //CREATE OR REPLACE PROCEDURE 是一个SQL语句通知Oracle数据库去创建一个叫做ske ...

  3. oracle存储过程实例

    oracle存储过程实例 分类: 数据(仓)库及处理 2010-05-03 17:15 1055人阅读 评论(2)收藏 举报 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的P ...

  4. HIbernate Oracle存储过程

    之前为了实现基于Hibernate+Oracle的存储过程调用,发现了一个又一个坑,然后一个一个的尝试解决. 需求:使用Hibernate调用Oracle的存储过程,需要支持的有动态表名.存储过程变量 ...

  5. oracle存储过程的例子

    oracle存储过程的例子 分类: 数据(仓)库及处理 2010-05-03 17:15 1055人阅读 评论(2)收藏 举报 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的 ...

  6. Java调用oracle存储过程通过游标返回临时表数据

    注:本文来源于 <  Java调用oracle存储过程通过游标返回临时表数据   > Java调用oracle存储过程通过游标返回临时表数据 项目开发过程中,不可避免的会用到存储过程返回结 ...

  7. .NET Core中使用Dapper操作Oracle存储过程最佳实践

    为什么说是最佳实践呢?因为在实际开发中踩坑了,而且发现网上大多数文章给出的解决方法都不能很好地解决问题.尤其是在获取类型为OracleDbType.RefCursor,输出为:ParameterDir ...

  8. Oracle存储过程update受外键约束的主键值时完整性冲突解决方式

    1.问题背景 尽管在数据库操作中我们并不提倡改动主键,可是确实在实际生活中有这种业务需求: 表A有主键KA,表B中声明了一个references A(KA)的外键约束.我们须要改动A中某条目KA的值而 ...

  9. NET Core中使用Dapper操作Oracle存储过程

    .NET Core中使用Dapper操作Oracle存储过程最佳实践   为什么说是最佳实践呢?因为在实际开发中踩坑了,而且发现网上大多数文章给出的解决方法都不能很好地解决问题.尤其是在获取类型为Or ...

随机推荐

  1. 【Linux】在虚拟机上安装CentOS7

    在配置好的机子上,可以装个双系统,但是在我自己的本子上,磁盘读写太垃圾了,连压缩卷 都执行不了,分不出空间,装不了CentOS系统,没办法,采用虚拟机的方式,把它转起来. -------------- ...

  2. Java 复制大文件方式(nio2 FileChannel 拷贝文件能力测试)

    目前为止,我们已经学习了很多 Java 拷贝文件的方式,除了 FileChannel 提供的方法外,还包括使用 Files.copy() 或使用字节数组的缓冲/非缓冲流.那个才是最好的选择呢?这个问题 ...

  3. cas4.0 session中返回更多的用户信息

    实现思路: 新增AccoutAttributeDao类继承StubPersonAttributeDao,重写getPerson方法.实际应用中我们只需要修改getPersion方法中的内容,根据实际情 ...

  4. 使用StringBuilder或StringBuffer简单优化

    使用StringBuilder或StringBuffer // join(["a", "b", "c"]) -> "a an ...

  5. ELK+Filebeat 安装配置入门

    本文地址 http://www.cnblogs.com/jasonxuli/p/6397244.html   https://www.elastic.co 上,elasticsearch,logsta ...

  6. OpenCV学习(34) 点到轮廓的距离

    在OpenCV中,可以很方便的计算一个像素点到轮廓的距离,计算距离的函数为: double pointPolygonTest(InputArray contour, Point2f pt, bool ...

  7. mini-parser

    https://leetcode.com/problems/mini-parser/ /** * // This is the interface that allows for creating n ...

  8. 直播【95秀】JNI 基本实现 简洁

    2017-2-8 基本架构 1.使用SurfaceView在UI层面展示视频 2.通过JNI调用C代码控制视频的播放.停止 基本功能 1.从服务器获取正在直播的主播的列表信息 2.进入直播界面 3.可 ...

  9. SQL基础(二):SQL命令

    1.SQL SELECT TOP 子句 SELECT TOP 子句用于规定要返回的记录的数目.SELECT TOP 子句对于拥有数千条记录的大型表来说,是非常有用的(或者比如选取某个最新的数据:我们可 ...

  10. Java基础(十二):包(package)

    一.Java 包(package): 为了更好地组织类,Java 提供了包机制,用于区别类名的命名空间.包的作用: 1.把功能相似或相关的类或接口组织在同一个包中,方便类的查找和使用. 2.如同文件夹 ...