暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

JDBC使用INSERT RETURN语句报错ORA-439

老杨 2019-04-18
699

问题描述

在给客户开发人员讲解LOB列的访问方式后,开发人员尝试在JDBC中使用包含RETURN的INSERT语句,但是出现了ORA-439错误。

专家解答

检查后发现客户的程序使用的还是PreparedStatement语句,而RETURNING语句,则是Oracle扩展的SQL语法,因此在声明语句的时候必须使用OraclePreparedStatement方式进行声明。
除了修改SQL语句外,使用OraclePreparedStatement声明语句变量外,还需要注册输出参数,类似的代码如下:

OraclePreparedStatement sqlstmt = 
(OraclePreparedStatement)conn.prepareStatement
("insert into t_lob values (?, ?, empty_clob()) returning contents into ?");
sqlstmt.setInt(1, 1);
sqlstmt.setString(2, "a");
sqlstmt.registerReturnParameter(3, OracleTypes.CLOB);
sqlstat.executeUpdate();
ResultSet resset = sqlstmt.getReturnResultSet();
IF (resset.NEXT())
{
CLOB contents = (CLOB)resset.getClob(2);
...
}

不过即使开发人员声明了OraclePreparedStatement语句,仍然找不到registerReturnParameter过程。
当前的数据库的版本是11.2.0.2,没有道理不支持RETURN语句,何况JDBC的RETURNING语句是从10.2的JDBC就引入新特性。
查询了一下当前客户端JDBC的驱动版本,发现居然还是9.2的版本,这就难怪使用RETURN语句的时候,会出现ORA-439的错误了。
很多时候数据库的版本已经升级到很高的版本,但是应用程序使用的版本或驱动没有进行升级,同样很多新特性无法使用。而且一般而言,推荐客户端驱动版本和所连接数据库的版本保持一致,这样出现BUG的可能性最小。

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论