新聞中心
以下的文章主要描述的是返回列表,我們大家都知道由于Oracle存儲(chǔ)過(guò)程是不存在返回值,Oracle存儲(chǔ)過(guò)程所有的返回值皆以out參數(shù)替代的,列表同樣也是不例外,但由于是集合,所以不能用一般的參數(shù),必須要用pagkage了.所以要分兩部分,

創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)服務(wù)商,為中小企業(yè)提供成都網(wǎng)站建設(shè)、網(wǎng)站制作服務(wù),網(wǎng)站設(shè)計(jì),綿陽(yáng)服務(wù)器托管等一站式綜合服務(wù)型公司,專(zhuān)業(yè)打造企業(yè)形象網(wǎng)站,讓您在眾多競(jìng)爭(zhēng)對(duì)手中脫穎而出創(chuàng)新互聯(lián)公司。
1, 建一個(gè)程序包。如下:
- CREATE OR REPLACE PACKAGE TESTPACKAGE AS
- TYPE Test_CURSOR IS REF CURSOR;
- end TESTPACKAGE;
2,建立Oracle存儲(chǔ)過(guò)程,存儲(chǔ)過(guò)程為:
- CREATE OR REPLACE PROCEDURE TESTC(p_CURSOR out TESTPACKAGE.Test_CURSOR) IS
- BEGIN
- OPEN p_CURSOR FOR SELECT * FROM HYQ.TESTTB;
- END TESTC;
可以看到,它是把游標(biāo)(可以理解為一個(gè)指針),作為一個(gè)out 參數(shù)來(lái)返回值的。
在java里調(diào)用時(shí)就用下面的代碼:
- package com.hyq.src;
- import java.sql.*;
- import java.io.OutputStream;
- import java.io.Writer;
- import java.sql.PreparedStatement;
- import java.sql.ResultSet;
- import oracle.jdbc.driver.*;
- public class TestProcedureTHREE {
- public TestProcedureTHREE() {
- }
- public static void main(String[] args ){
- String driver = "oracle.jdbc.driver.OracleDriver";
- String strUrl = "jdbc:oracle:thin:@127.0.0.1:1521:hyq";
- Statement stmt = null;
- ResultSet rs = null;
- Connection conn = null;
- try {
- Class.forName(driver);
- conn = DriverManager.getConnection(strUrl, "hyq", "hyq");
- CallableStatement proc = null;
- proc = conn.prepareCall("{ call hyq.testc(?) }");
- proc.registerOutParameter(1,oracle.jdbc.OracleTypes.CURSOR);
- proc.execute();
- rs = (ResultSet)proc.getObject(1);
- while(rs.next())
- {
- System.out.println("
"); " + rs.getString(1) + " "+rs.getString(2)+" - }
- }
- catch (SQLException ex2) {
- ex2.printStackTrace();
- }
- catch (Exception ex2) {
- ex2.printStackTrace();
- }
- finally{
- try {
- if(rs != null){
- rs.close();
- if(stmt!=null){
- stmt.close();
- }
- if(conn!=null){
- conn.close();
- }
- }
- }
- catch (SQLException ex1) {
- }
- }
- }
- }
上述的相關(guān)內(nèi)容就是對(duì)Oracle存儲(chǔ)過(guò)程的描述,希望會(huì)給你帶來(lái)一些幫助在此方面。
【編輯推薦】
- 訪問(wèn) Oracle 數(shù)據(jù)庫(kù)的實(shí)例描述
- 對(duì)Oracle數(shù)據(jù)庫(kù)設(shè)計(jì)中字段的正確使用方案
- Oracle 10g歸檔日志
- Oracle服務(wù)器如何進(jìn)一步的獲取權(quán)限
- 如何用Oracle 9i全索引掃描完成任務(wù)
當(dāng)前文章:Oracle存儲(chǔ)過(guò)程中不存在返回值的緣由
標(biāo)題URL:http://www.dlmjj.cn/article/dhpdjdp.html


咨詢(xún)
建站咨詢(xún)
