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

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

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

    隨筆 - 6  文章 - 129  trackbacks - 0
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(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;

      回復  更多評論
      
    主站蜘蛛池模板: 99精品视频免费观看| 一级大黄美女免费播放| **真实毛片免费观看| 国产亚洲成AV人片在线观黄桃| 无码 免费 国产在线观看91| 国产午夜无码视频免费网站| 久久水蜜桃亚洲AV无码精品| 亚洲av无码成人精品区在线播放| 免费无码国产V片在线观看| 亚洲国产精品无码久久久久久曰| 一级片在线免费看| 国产成人精品日本亚洲| 亚洲精品在线免费看| 亚洲日本久久一区二区va| 成人免费毛片视频| 一区在线免费观看| 亚洲AV无码不卡无码| 免费看片在线观看| 色偷偷尼玛图亚洲综合| 国产亚洲精品看片在线观看| 无码精品人妻一区二区三区免费看| 精品国产一区二区三区免费看| 黄色一级视频免费观看| 亚洲区小说区激情区图片区| 99免费视频观看| 亚洲高清国产拍精品熟女| 亚洲一区二区女搞男| 免费观看激色视频网站(性色)| 亚洲丰满熟女一区二区哦| 区久久AAA片69亚洲| 曰曰鲁夜夜免费播放视频 | 亚洲国产成人久久精品动漫| 久久精品国产免费观看| 国产偷国产偷亚洲高清人| 久久久久久久久亚洲| 永久黄网站色视频免费| 免费国产成人18在线观看| 亚洲乱亚洲乱妇24p| 亚洲AV无码一区二区二三区入口| 成人毛片18岁女人毛片免费看| 99久久免费国产精品热|