<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆 - 6  文章 - 129  trackbacks - 0
    <2013年5月>
    2829301234
    567891011
    12131415161718
    19202122232425
    2627282930311
    2345678

    常用鏈接

    留言簿(14)

    隨筆檔案(6)

    文章分類(467)

    文章檔案(423)

    相冊

    收藏夾(18)

    JAVA

    搜索

    •  

    積分與排名

    • 積分 - 825681
    • 排名 - 49

    最新評論

    閱讀排行榜

    評論排行榜

     

    調用無入參的函數

    函數定義

    CREATE OR REPLACE Function f_getstring Return Varchar2 Is
    Begin
     Return ''String value'';
    End f_getstring;

    調用函數的Java片斷

       CallableStatement cstmt = con.prepareCall("{?=call f_getstring}");
       cstmt.registerOutParameter(1, Types.VARCHAR);
       cstmt.execute();
       String strValue = cstmt.getString(1);
       System.out.println("The return value is:" + strValue);
       cstmt.close();

    調用有一個入參,一個輸出參數以及一個字符串返回值的函數

    函數定義

    CREATE OR REPLACE Function f_Getinfo(Id Integer, Age Out Integer) Return Varchar2 Is
    Begin
     Age := 10;
     Return ''The age is:'' || Id;
    End f_Getinfo;

    調用函數的Java代碼片斷

       CallableStatement cstmt = con
         .prepareCall("{?=call f_getinfo(?,?)}");
       cstmt.registerOutParameter(1, Types.VARCHAR);
       cstmt.setInt(2, 11);
       cstmt.registerOutParameter(3, Types.INTEGER);
       cstmt.execute();
       String strValue = cstmt.getString(1);
       int age = cstmt.getInt(3);
       System.out.println("The return value is:" + strValue
         + " and age is:" + age);
       cstmt.close();



    posted on 2009-05-12 10:27 Ke 閱讀(6369) 評論(2)  編輯  收藏 所屬分類: oraclejava

    FeedBack:
    # re: Java調用Oracle函數 2013-05-12 15:02 wms
    package com;

    import java.sql.CallableStatement;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import java.sql.Types;

    public class TestProcedureOne {

    public TestProcedureOne() {

    }

    public static void main(String[] args) {

    String driver = "oracle.jdbc.driver.OracleDriver";
    String strUrl = "jdbc:oracle:thin:@localhost:1521:orcl";
    Connection conn = null;
    CallableStatement cstmt = null;

    try {

    Class.forName(driver);
    conn = DriverManager.getConnection(strUrl, "wms", "wms");

    cstmt = conn.prepareCall("{?=call add_three_numbers(?,?,?)}");

    cstmt.registerOutParameter(1, Types.INTEGER);

    cstmt.setInt(2,4);
    cstmt.setInt(3,5);
    cstmt.setInt(4,6);

    cstmt.execute();
    System.out.println("調用函數add_three_numbers:"+cstmt.getInt(1));

    } catch (SQLException ex2) {
    ex2.printStackTrace();
    } catch (Exception ex2) {
    ex2.printStackTrace();
    }

    finally {

    try {

    if (cstmt != null) {
    cstmt.close();
    if (conn != null) {
    conn.close();
    }
    }
    } catch (SQLException e) {
    System.out.println("SQL state" + e.getSQLState());
    System.out.println("錯誤消息" + e.getMessage());
    System.out.println("錯誤代碼" + e.getErrorCode());
    e.printStackTrace();
    }

    }

    }

    }
      回復  更多評論
      
    # re: Java調用Oracle函數 2013-05-12 15:04 wms
    補充:上例使用的函數(oracle 11g中編寫)
    代碼:

    create or replace FUNCTION add_three_numbers ( a NUMBER:=0, b NUMBER:=0, c NUMBER:=0 )
    RETURN NUMBER
    AS
    Result1 NUMBER:=0;
    BEGIN
    Result1:=(a+b+c);
    RETURN Result1;
    END add_three_numbers;

      回復  更多評論
      
    主站蜘蛛池模板: 永久免费精品影视网站| 无码国产精品一区二区免费| 亚洲午夜未满十八勿入| 国产精品视频免费观看| 午夜在线亚洲男人午在线| 亚洲妇熟XXXX妇色黄| 最新中文字幕电影免费观看| 51午夜精品免费视频| 亚洲av成人一区二区三区| 亚洲人成无码网WWW| 无码国产精品一区二区免费 | 久久精品亚洲日本波多野结衣| 亚洲午夜爱爱香蕉片| 18国产精品白浆在线观看免费| 免费毛片毛片网址| 亚洲国产精品专区| a级亚洲片精品久久久久久久| 国产免费看JIZZ视频| 99久久99这里只有免费的精品| 国产精品亚洲专区在线观看| 亚洲色欲一区二区三区在线观看| 国产精品美女午夜爽爽爽免费| 中国毛片免费观看| 国产精品亚洲一区二区三区| 亚洲午夜精品一区二区| 亚洲精品麻豆av| 免费看的一级毛片| 免费看男女下面日出水来| 男女一进一出抽搐免费视频 | 国产精品亚洲视频| 美女黄网站人色视频免费国产 | 国产美女在线精品免费观看| 成全在线观看免费观看大全| 激情无码亚洲一区二区三区| 亚洲制服丝袜一区二区三区| 亚洲男人天堂2017| 亚洲国产一二三精品无码| 亚洲午夜福利精品久久| 国产精品无码一区二区三区免费| 麻豆一区二区免费播放网站| 日韩人妻无码精品久久免费一|