Oracle 12c中varchar2的扩展长度

时间:2015-05-07 00:26:55

标签: oracle varchar2

我认为我应该在Java应用程序中提供新的扩展varchar2限制。这是我到目前为止所做的:

  1. 根据建议的程序将MAX_STRING_SIZE更改为EXTENDED。
  2. 将相关列扩展为32767个字符。
  3. 跑完程序。
  4. Java调用ResultSet.updateString( str, idx )运行正常,但是当我来到ResultSet.updateRow()时,我最终在Java异常中引用了Oracle错误:

      

    java.sql.SQLException:ORA-01461:只能绑定LONG值以插入LONG列

    完整的错误堆栈(或至少没有引用我的代码的部分)如下:

    java.sql.SQLException: ORA-01461: can bind a LONG value only for insert into a LONG column
    at oracle.jdbc.driver.SQLStateMapping.newSQLException(SQLStateMapping.java:70)
    at oracle.jdbc.driver.DatabaseError.newSQLException(DatabaseError.java:112)
    at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:173)
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:455)
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:413)
    at oracle.jdbc.driver.T4C8Oall.receive(T4C8Oall.java:1030)
    at oracle.jdbc.driver.T4CPreparedStatement.doOall8(T4CPreparedStatement.java:194)
    at oracle.jdbc.driver.T4CPreparedStatement.executeForRows(T4CPreparedStatement.java:947)
    at oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1222)
    at oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3381)
    at oracle.jdbc.driver.OraclePreparedStatement.executeUpdate(OraclePreparedStatement.java:3462)
    at oracle.jdbc.driver.UpdatableResultSet.executeUpdateRow(UpdatableResultSet.java:3317)
    at oracle.jdbc.driver.UpdatableResultSet.updateRow(UpdatableResultSet.java:2281)
    

    据我所知,这应该是它。但要么我忘记了一些基本的东西,要么这肯定是一个错误(可能在jdbc库中)。

1 个答案:

答案 0 :(得分:1)

您必须使用12c中的JDBC驱动程序。