Oracle认证 百分网手机站

Java中调用Oracle包的过程

时间:2018-01-29 15:24:54 Oracle认证 我要投稿

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 java.sql.*;

  import oracle.jdbc.driver.*;

  public class proctest {

  public static void main(String[] args) {

  proctest pc = new proctest();

  pc.ShowContent();

  }

  String sDBDriver="oracle.jdbc.driver.OracleDriver";

  String sConnStr="jdbc:oracle:thin:@10.3.8.48:1521:ORADB";

  Connection connect=null;

  ResultSet rs = null;

  public proctest(){

  try{

  Class.forName(sDBDriver);

  }

  catch(ClassNotFoundException e){

  System.err.println(e.getMessage());

  }

  }

  public ResultSet ShowContent()

  {

  try{

  connect = DriverManager.getConnection(sConnStr,"SHUIBJ","SHUIBJ");

  CallableStatement stmt = connect.prepareCall("{call PKG_TEST.GET(?,?,?)}");

  stmt.setString(1,"all"); //输入参数

  stmt.registerOutParameter(2,Types.CHAR); //输出参数为普通参数

  stmt.registerOutParameter(3,OracleTypes.CURSOR); //输出参数为结果集参数

  stmt.executeQuery();

  rs = ((OracleCallableStatement) stmt).getCursor(3); //得到输出结果集参数

  ResultSetMetaData rsmd = rs.getMetaData();

  int numberOfColumns = rsmd.getColumnCount();

  String str = stmt.getString(2);

  System.out.println("第二个参数为:"+str);

  System.out.println("结果集列数"+numberOfColumns);

  //列出结果集中的记录

  ResultSetMetaData md = rs.getMetaData();

  int nColumns = md.getColumnCount();

  for (int i=1;i<=nColumns;i++){

  System.out.print(md.getColumnName(i)+((i==nColumns)?"\n":"\t"));

  if(i==2) System.out.print("\t");

  }

  while (rs.next()){

  for(int i=1;i<=nColumns;i++){

  System.out.print(rs.getString(i)+((i==nColumns)?"\n":"\t"));

  }

  }

  }

  catch(SQLException ex){

  System.err.println(ex.getMessage()+"连数据库有问题!");

  }

  return rs;

  }

  }

  输出结果为:

  第二个参数为:Hello,may~

  结果集列数4

  BOOKID BOOKNAME PUBLISHER PRICE

  001-22-23-1 jsp 应用开发详解 电子工业出版社 123

  123 uml参考手册 机械工业出版社 34

【Java中调用Oracle包的过程】相关文章:

1.Java如何调用WebService

2.java程序中如何调用linux命令

3.java调用cmd命令大全

4.Java调用Linux命令行

5.java调用linux命令传输远程大文件

6.Java怎么编写Oracle存储过程

7.Java中import的使用

8.在java中Synchronized的用法