中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JDBC存儲過程在Oracle中如何獲取結果集

發布時間:2021-10-12 18:46:23 來源:億速云 閱讀:235 作者:小新 欄目:編程語言

這篇文章給大家分享的是有關JDBC存儲過程在Oracle中如何獲取結果集的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

1. 關于Oracle和結果集

其實在大多數情況下,我們并不需要從Oracle中的JDBC存儲過程里返回一個或多個結果集,除非迫不得已。如果大家用過MS SQL Server或Sybase SQL Server,那么從存儲過程返回一個動態的結果集是一件非常容易的事情,只要在存儲過程結束時寫上

“select column1,column2,.... from table_list where condition“

就可以了。

但在Oracle中不能這樣做. 我們必須使用Oracle Cursor.在Oracle PL/SQL中,Cursor用來返回一行或多行記錄,借助Cursor,我們可以從結果集中取得所有記錄.

Cursor并不難,但是要從Oracle中JDBC存儲過程中返回結果集, 就需要用到Cursor變量,Cursor變量Oracle PL/SQL的類型是REF CURSOR, 我們只要定義了REF CURSOR 類型就可以使用Cursor變量. 比如我們可以這樣定義:
TYPE ref_cursor IS REF CURSOR;

了解了Cursor以及Cursor變量,下面就介紹如何使用Cursor變量給JDBC返回結果集.

2. 定義表結構

在以下例子里,我們要用到一張表Hotline.

Create table hotline(country varchar2(50),pno varchar2(50));

3. 定義存儲過程

  1. create or replace package PKG_HOTLINE istype HotlineCursorType is REF CURSOR;  

  2. function getHotline return HotlineCursorType;  

  3. end;  

  4. create or replace package body PKG_HOTLINE isfunction getHotline return HotlineCursorType
    ishotlineCursor HotlineCursorType;  

  5. beginopen hotlineCursor for select * from hotline;  

  6. return hotlineCursor;  

  7. end;  

  8. end

在這個存儲過程里,我們定義了HotlineCursorType 類型,并且在存儲過程中簡單地查找所有的記錄并返回HotlineCursorType.

4. 測試JDBC存儲過程

在Oracle SQL/Plus里登陸到數據庫. 按以下輸入就看到返回的結果集.

SQL> var rs refcursor;SQL> exec :rs := PKG_HOTLINE.getHotline;SQL> print rs;

5. Java調用

簡單地寫一個Java Class.

….public void openCursor(){Connection conn = null;ResultSet rs = null;   CallableStatement stmt = null;   String sql = “{? = call PKG_HOTLINE.getHotline()}“;   try{conn = getConnection();stmt = conn.prepareCall(sql);   stmt.registerOutParameter(1,OracleTypes.CURSOR);   stmt.execute();   rs = ((OracleCallableStatement)stmt).getCursor(1);   while(rs.next()){String country = rs.getString(1);   String pno = rs.getString(2);   System.out.println(“country:“ country “|pno:” pno);   }}catch(Exception ex){ex.printStackTrace();   }finally{closeConnection(conn,rs,stmt);   }}…..

這樣就完成了JDBC存儲過程對Oracle結果集的調用。

感謝各位的閱讀!關于“JDBC存儲過程在Oracle中如何獲取結果集”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

汪清县| 黄梅县| 札达县| 会同县| 鱼台县| 贵阳市| 潞城市| 石泉县| 虎林市| 蕉岭县| 南投市| 鹤岗市| 修武县| 和平县| 永善县| 安多县| 斗六市| 木里| 阿克| 景宁| 乌兰浩特市| 贺州市| 简阳市| 台南市| 延川县| 师宗县| 玉林市| 延吉市| 武宁县| 涟水县| 甘德县| 三门峡市| 洛川县| 和平县| 屏东市| 商丘市| 涞源县| 宾川县| 深水埗区| 嘉兴市| 大竹县|