小编Sau*_*rav的帖子

位置 5 处的 SQL92 字符串格式错误。需要“call”吗?

正如标题所示,我在尝试从 Java 代码调用 Oracle 函数时遇到异常。我尝试了一些事情但没有成功。此时我不知道该怎么办。任何帮助或建议将不胜感激。提前致谢。

Java

CallableStatement cstmt = p_con.prepareCall("{? = CALL FXRATE_ENTITY(?, ?, ?, ?)}");
         cstmt.registerOutParameter(1, java.sql.Types.INTEGER);

         cstmt.setString(2, "SCR");
         cstmt.setString(3,l_srccur);
         cstmt.setString(4, l_tfcurr);
         cstmt.setString(5, "B001");

         cstmt.execute();
         res = cstmt.getString(1);
Run Code Online (Sandbox Code Playgroud)

Oracle Function

FUNCTION FXRATE_ENTITY(CODCURRBASE IN VARCHAR, LCODCURRFROM IN VARCHAR, LCODCURRTO IN VARCHAR, LIDENTITY IN VARCHAR)
  RETURN NUMBER IS
  CODCUR_L VARCHAR2(3);
BEGIN
  IF (LCODCURRTO = '*') THEN
    RETURN NVL(FXRATE(CODCURRBASE, LCODCURRFROM, CODCURRBASE, LIDENTITY),
               0);
  ELSE
    RETURN NVL(FXRATE(CODCURRBASE, LCODCURRFROM, LCODCURRTO, LIDENTITY), 0);
  END IF;
END;
Run Code Online (Sandbox Code Playgroud)

java oracle jdbc

2
推荐指数
1
解决办法
2154
查看次数

标签 统计

java ×1

jdbc ×1

oracle ×1