jdbc中调用oracle函数

1、创建表

 create table stud(
 sid int,
 sname varchar2(50),
 age number,
 score number(4,2))
并插入一些数据(自己手动插入一些吧)
2、创建函数

create or replace function fun_getScores(
       v_age in stud.age%type
)
return number
is
       v_score number;
begin
      
       select sum(score) into v_score from stud where age > v_age;
       return v_score;
      
--异常处理
exception
       when others then
       dbms_output.put_line(sqlcode||sqlerrm);
       return -1;
end;
3、jdbc中调用


import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.sql.Types;


public class TestFun {


 public void test(){

 


  Connection con = null;
  Statement st = null;
  ResultSet rs = null;
  CallableStatement cst = null;
  try{
   Class.forName("oracle.jdbc.driver.OracleDriver");
   //下面的tan是数据库名,默认是orcl,love是访问密码,默认是tiger,
          //1521是端口号,默认是1521
   con = DriverManager.getConnection

("jdbc:oracle:thin:@192.168.1.103:1521:tan","scott","love");
   String sql =  "{? = call fun_getScores(?)}";
   cst = con.prepareCall(sql);
   cst.registerOutParameter(1, Types.NUMERIC);
   cst.setDouble(2, 2);
   cst.execute();
   double result = cst.getDouble(1);
   
   System.out.println("年龄超过2岁学生的成绩总和 "+result);
  }catch(Exception e){
   e.printStackTrace();
  }finally{
   try{
    if(rs !=null){
     rs.close();
    }
    if(st!=null){
     st.close();
    }
    if(cst != null){
     cst.close();
    }
    if(con != null){
     con.close();
    }
   }catch(Exception e){
    e.printStackTrace();
   }
  }

 


 }

 

 

 

 public static void main(String[] args) {
  // TODO Auto-generated method stub
  TestFun tf = new TestFun();
  tf.test();
 }

 

}

 

 

 

 

 

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值