在线等publicintcalculateTimeInterval(Integerid){con=SqlHelper.connect();try{statement=con.createStatement();cs=con.prepareCall("callCALCULATETIME(?,?)");cs.setInt(1,id);c...
在线等
public int calculateTimeInterval(Integer id) {
con = SqlHelper.connect();
try {
statement = con.createStatement();
cs = con.prepareCall("call CALCULATETIME(?,?)");
cs.setInt(1,id);
cs.registerOutParameter(2, oracle.jdbc.OracleTypes.INTEGER);
cs.executeUpdate();
Integer result = cs.getInt(2);
if(result==-1){
System.out.println("出错,返回结果出错");
}else{
return result;
}
} catch (SQLException ex) {
ex.printStackTrace();
}
finally{
try {
cs.close();
statement.close();
con.close();
} catch (SQLException ex) {
ex.printStackTrace();
}
}
return -1;
}
下面是这个存储过程,在plsql下如果brid为1的话,返回值应该是1,但是java中始终返回0
CREATE OR REPLACE procedure calculateTime(brid in NUMBER,timequality out INTEGER)
as
intime date;
outtime date;
begin
select br_outdate,br_indate into outtime,intime from borrowreturn where br_id= to_char (brid);
--timequality:=ceil((To_date(intime , 'yyyy-mm-dd hh24-mi-ss') - To_date(outtime, 'yyyy-mm-dd hh24-mi-ss')));
select ceil((To_date(intime , 'yyyy-mm-dd hh24-mi-ss') - To_date(outtime, 'yyyy-mm-dd hh24-mi-ss'))) into timequality from dual;
--DBMS_OUTPUT.PUT_LINE('the interval of time is '||timequality);
EXCEPTION
WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE('error');
end;
是这样的,statement = con.createStatement();这句话是我写着玩的,cs是callableStatement对象,整个过程调用在java中并无报错,并且存储过程没有错误,我已经在oracle的sqlplus中进行测试,
总结着说,就是存储过程正确,java调用不报错,但是结果是错误的,应该是1,我怀疑是传入错误,brid in NUMBER这句我该成brid in varchar,非2后setString也会出错,你说奇怪不奇怪!如果您能帮助我解决我将感激不尽,100分献上
对了,我是用的oracle数据库,还有两个调用存储函数的,存储函数可以返回正确的值,存储过程就不行,我真是醉了。
展开