Oracle的預存程序返回結果集

來源:互聯網
上載者:User

Oracle預存程序:

CREATE OR REPLACE PROCEDURE getcity (  citycode     IN       VARCHAR2,  ref_cursor   OUT      sys_refcursor /* 這個sys_refcursor類型在SYS.STANDARD包中 */)ASBEGIN  OPEN ref_cursor FOR    SELECT *      FROM tb_city_code     WHERE city_code = citycode;END;

Java調用代碼:

try {          DriverManager.registerDriver (new oracle.jdbc.OracleDriver());          Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:wjw", "sms", "sms");          CallableStatement stmt = conn.prepareCall("BEGIN GETCITY(?, ?); END;");          //CallableStatement stmt = conn.prepareCall("{ call GETCITY(?, ?) }");  //用此調用方法不能實現多行文法          stmt.setString(1, "021");          stmt.registerOutParameter(2, -10 /* OracleTypes.CURSOR = -10 */); //REF CURSOR(OracleTypes.CURSOR==-10)          stmt.execute();          ResultSet rs = (ResultSet) stmt.getObject(2);          while (rs.next()) {            System.out.println(rs.getString("CITY_NAME"));          }          rs.close();          rs = null;          stmt.close();          stmt = null;          conn.close();          conn = null;        }        catch (SQLException e) {          System.out.println(e.getLocalizedMessage());        }


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.