oracel package包中的存储过程的定义和使用

最近的项目中用到了oracle package包中的存储过程。本文以一个简单的插入为例,简述从存储过程的定义,包括PACKAGE的定义和PACKAGE BODY的定义,到存储过程的使用。

首先用sql语句创建一个USER_INFO表,sql语句如下:

*****************USER_INFO表创建语句********************

-- Create table
create table USER_INFO
(
id VARCHAR2(4),
username VARCHAR2(15),
pass<a href="http://www.it165.net/edu/ebg/" target="_blank" class="keylink">word</a> VARCHAR2(15),
address VARCHAR2(30)
);

然后定义存储过程USER_INSERT,先定义PACKAGE包头USER_CONTROL,sql语句如下:

******************存储过程包头USER_CONTROL*********************************

CREATE OR REPLACE PACKAGE USER_CONTROL AS
PROCEDURE USER_INSERT (
in_id user_info.id%TYPE,
in_username user_info.username%TYPE,
in_pass<a href="http://www.it165.net/edu/ebg/" target="_blank" class="keylink">word</a> user_info.password%TYPE,
in_address user_info.address%TYPE
);
END USER_CONTROL;

在定义PACKAGE BODY包体USER_CONTROL,这里包头和包体的名字要相同,sql语句如下:

****************存储过程包体***************************

CREATE OR REPLACE PACKAGE BODY USER_CONTROL AS
PROCEDURE USER_INSERT (
in_id user_info.id%TYPE,
in_username user_info.username%TYPE,
in_password user_info.password%TYPE,
in_address user_info.address%TYPE
)IS
BEGIN
INSERT INTO USER_INFO(ID,USERNAME,PASSWORD,ADDRESS) VALUES(in_id,in_username,in_password,in_address);
END;
END USER_CONTROL;

这样,一个简单的存储过程就定义好了。下面就是调用这个存储过程了。

用SQL语句就可以调用这个存储过程。

*******************调用存储过程*****************

DECLARE
BEGIN
USER_CONTROL.USER_INSERT('11','11,'11','11'),
END;

最后在提交这个事务就可以把数据插入到表中了。

当然有的同学会说,你一个插入的功能就写了这么多代码,我一个insert语句不就搞定了嘛。

我这里只是给了一个存储过程从定义到使用的步骤。并没有在存储过程中写太多动作。

其实我们可以简单的这样理解,把PACKAGE包头理解为JAVA中的接口,把PACKAGE BODY理解为JAVA中实现这个接口的类,而里面的存储过程就相当于类中的方法了。

希望对大家有帮助吧。

转载于:https://my.oschina.net/luqin/blog/398084

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值