从 postgresql 的文档中我发现:
con.setAutoCommit(false);
过程调用。
CallableStatement proc = con.prepareCall("{ ? = call doquery ( ? ) }");
proc.registerOutParameter(1, Types.Other);
proc.setInt(2, -1);
proc.execute();
ResultSet results = (ResultSet) proc.getObject(1);
参考这里
虽然,我试图创建一个程序,就像
CREATE OR REPLACE FUNCTION PSSQLPRC(pA IN VARCHAR,pB IN NUMERIC,PC OUT NUMERIC)
RETURNS NUMERIC
AS $$<br> begin
... ...
end;
$$ Language PLPGSQL;
使用java调用postgresql过程如下
CallableStatement proc = con.prepareCall("{ ? = call PSSQLPRC(?,?,?) }");
proc.registerOutParameter(1, Types.NUMERIC);
proc.setString(2,"abc");
proc.setInt(3,10);
proc.registerOutParameter(4, Types.NUMERIC);
proc.execute();
当 CallableStatement 的对象执行时,会发生错误。我能做些什么来解决这个错误?上述陈述是否正确?