Java中调用Oracle包的过程
在Java中调用Oracle包是我们程序员经常遇到的.事情,那么它具体的过程是怎么样的呢?我们一起来看看!
一、先在oracle中编写测试过程
1、首选建一个测试表
-- Create table
create table BOOK
(
BOOKID VARCHAR2(50) not null,
BOOKNAME VARCHAR2(50) not null,
PUBLISHER VARCHAR2(50) not null,
PRICE VARCHAR2(50) null
)
2、编写ORACLE测试过程
CREATE OR REPLACE PACKAGE pkg_test
AS
TYPE myrctype IS REF CURSOR;
PROCEDURE get (p_id VARCHAR2, p_str OUT VARCHAR2, p_rc OUT myrctype);
END pkg_test;
/
CREATE OR REPLACE PACKAGE BODY pkg_test
AS
PROCEDURE get (p_id VARCHAR2, p_str OUT VARCHAR2,p_rc OUT myrctype)
IS
sqlstr VARCHAR2 (500);
BEGIN
p_str := ''''Hello,may~'''';
IF p_id = ''''all'''' THEN
OPEN p_rc FOR
SELECT *
FROM BOOK;
ELSE
sqlstr :=
''''select *
from BOOK where BOOKID=:w_id'''';
OPEN p_rc FOR sqlstr USING p_id;
END IF;
END get;
END pkg_test;
/
在这里我们建立了一个输入参数,为普通类型,两个输出参数,其中一个为普通VARCHAR2型,另一个为特殊的记录集类型。
(注:在数据库端测试一下这个过程,以确保没有问题,开始下面的操作~:)
二、编写JAVA代码测试过程
/*
* 创建日期: 2003-8-8
*/
package JDBC;
/**
* 作者:may
* 时间:15:09:23
*/
import .*;
import er.*;
public class proctest {
public static void main(String[] args) {
proctest pc = new proctest();
Content();
}
String sDBDriver="leDriver";
String sConnStr="jdbc:oracle:thin:@:ORADB";
Connection connect=null;
ResultSet rs = null;
public proctest(){
try{
ame(sDBDriver);
}
catch(ClassNotFoundException e){
tln(essage());
}
}
public ResultSet ShowContent()
{
try{
connect = onnection(sConnStr,"SHUIBJ","SHUIBJ");
CallableStatement stmt = areCall("{call PKG_(?,?,?)}");
tring(1,"all"); //输入参数
sterOutParameter(2,); //输出参数为普通参数
sterOutParameter(3,OR); //输出参数为结果集参数
uteQuery();
rs = ((OracleCallableStatement) stmt)ursor(3); //得到输出结果集参数
ResultSetMetaData rsmd = etaData();
int numberOfColumns = olumnCount();
String str = tring(2);
tln("第二个参数为:"+str);
tln("结果集列数"+numberOfColumns);
//列出结果集中的记录
ResultSetMetaData md = etaData();
int nColumns = olumnCount();
for (int i=1;i<=nColumns;i++){
t(olumnName(i)+((i==nColumns)?"n":"t"));
if(i==2) t("t");
}
while (()){
for(int i=1;i<=nColumns;i++){
t(tring(i)+((i==nColumns)?"n":"t"));
}
}
}
catch(SQLException ex){
tln(essage()+"连数据库有问题!");
}
return rs;
}
}
输出结果为:
第二个参数为:Hello,may~
结果集列数4
BOOKID BOOKNAME PUBLISHER PRICE
001-22-23-1 jsp 应用开发详解 电子工业出版社 123
-
oracle sysdba级用户的认证方式
经过系统化的实训,让这部分人群能够迅速掌握Oracle最新的核心技术,并能胜任企业大型数据库管理、维护、开发工作。下面是小编整理的关于oraclesysdba级用户的认证方式,欢迎大家参考!Oracle对于普通账户和超级管理员(指sysdba和sysoper)的认证机制不一样,前者是通过...
-
2017年oracle数据库认证考试
OracleDBA通常都要和IT行业的技术专家打交道,因此,他或她就必须能够为所有访问Oracle数据库的开发人员或程序员清晰明了的解释Oracle概念。下面是小编整理的关于oracle数据库认证考试,欢迎大家参考!随着大数据时代的来临和O2O的快速发展。市场对于Oracle数据库技...
-
ORACLE与excel的数据互传方法
众所周知,MicrosoftExcel能很直观而方便地进行数据输入,统计,生成图表,但它的数据管理能力有限,对大量的数据查询能力不足,如果利用它数据计算方面的优点和大型数据库ORACLE的数据查询优点,可以设计出功能强大的数据处理系统。假设与Excel数据文件相对应的职工情况表E...
-
Oracle11g认证考试主要途径
Oracle11g有400多项功能,经过了1500多个小时的测试,开发工作量达到了3.6万人/月,相当于1000名员工连续研发3年。Oracle11g提供了高性能、伸展性、可用性和安全性,并能更方便地在低成本服务器和存储设备组成的网格上运行,相对过往版本而言,Oracle11g具有了与众不同的...
相关文章
- 如何理解Javascript的caller,callee,call,apply区别
- 简单地分析Java线程编程中ThreadLocal类的使用
- 如何理解Javascript的caller,callee,call,apply区别
- Java并发编程:深入剖析ThreadLocal
- Java怎么编写Oracle存储过程
- 如何理解Javascript的caller,callee,call,apply区别
- 如何理解Javascript的caller,callee,call,apply区别
- 如何理解Javascript的caller,callee,call,apply区别
- 如何理解Javascript的caller,callee,call,apply区别
- 如何理解Javascript的caller,callee,call,apply区别