亚洲一级电影在线观看,九九精品无码专区免费,亚洲AV无码资源在线观看 ,欧美国产高清

Java中調用Oracle包的過程

時間:2024-06-27 21:21:55 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

主站蜘蛛池模板: 国产精品人成视频免费国产| 日韩高清国产一区在线| 麻豆国产成人av在线播放欲色| 成人午夜网址| 99这里只有精品6| 欧美日韩无套内射另类| 精品无码一区二区三区水蜜桃| 日本一卡二卡四卡无卡乱码视频免费 | 亚洲综合区小说区激情区| 制服丝袜亚洲欧美中文字幕| 国产精品国产主播在线观看| 浪潮av激情高潮国产精品| 成人影片麻豆国产影片免费观看| 国产成人免费高清直播| 成人无码看片在线观看免费| 天堂国产+人+综合+亚洲欧美| 福利姬液液酱喷水| 91视频日本| 综合在线 亚洲 成人 欧美| 国产日韩综合一区在线观看| 国产成人亚洲欧美日韩| 五月激激激综合网色播| 豆国产97在线 | 亚洲| 鄯善县| 国产aⅴ人妻互换一区二区| 大伊香蕉精品一区二区| 呼玛县| 大肉大捧一进一出好爽视频动漫| 久久国产热这里只有精品| 镇赉县| 五月丁香综合激情六月久久 | 封开县| 亚洲欧美成人综合| 精品国内综合一区二区| 香蕉免费一区二区三区| 亚洲精品久久一区二区三区四区| 亚洲精品偷拍影视在线观看| 男人j进入女人j内部免费网站| 中国一级毛片视频 | 91国内视频在线观看| 国产成人一区二区三区|