ORACLE package包中的存储过程的定义和使用
来源:互联网 发布:本尼迪克特 知乎 编辑:程序博客网 时间:2024/05/19 13:28
最近的项目中用到了oracle package包中的存储过程。本文以一个简单的插入为例,简述从存储过程的定义,包括PACKAGE的定义和PACKAGE BODY的定义,到存储过程的使用。
首先用sql语句创建一个USER_INFO表,sql语句如下:
*****************USER_INFO表创建语句********************
-- Create table
create table USER_INFO
(
id VARCHAR2(4),
username VARCHAR2(15),
password 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_password 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中实现这个接口的类,而里面的存储过程就相当于类中的方法了。
希望对大家有帮助吧。
本文出自 “一个风向” 博客,请务必保留此出处http://lanffy.blog.51cto.com/6452125/1318744
- ORACLE package包中的存储过程的定义和使用
- ORACLE package包中的存储过程的定义和使用
- Oracle中定义package以及存储过程的使用
- Oracle Package包的定义及使用
- oracle存储过程--包package
- Oracle Package中的包变量的使用
- oracle包中的存储过程
- MSSQL 存储过程的定义和使用
- Oracle存储过程,临时表的创建、删除,变量的定义和使用
- Oracle Package包使用
- Delphi 调用Oracle中包(package)中的过程
- java调用oracle包中的存储过程
- Oracle 触发器调用包中的存储过程
- oracle存储过程和游标的使用
- oracle存储过程和游标的使用
- oracle 存储过程和游标的使用
- oracle存储过程和游标的使用
- C#调用Oracle的存储过程,其参数为数组类型”中的Package
- Android中广告轮播框架Banner----(功能很全面)
- 2017第五届中国用户体验峰会即将于11月在京举办!
- windows查看端口占用
- linux执行程序:error while loading shared libraries
- Handler
- ORACLE package包中的存储过程的定义和使用
- 第四周项目三(2)—两个链表的拼接
- 数据结构上机实践第三周项目4(2)—顺序表应用
- springboot 集成dubbo
- 使用 lombok 简化 Java 代码
- 朴素贝叶斯分类
- 第4周实践项目1 建立单链表(非多组织结构)
- Spring之Bean总结(一)
- 适配ioiOS11