如何修复滚动敏感结果集更新期间抛出的错误?

时间:2012-10-08 12:39:56

标签: jdbc

我正在尝试更新ResultSet中的一行,但是它会抛出错误。我将常量值ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE传递给createStatement。

这是我的代码:

public void modifyPrice(float percentage) throws SQLException {
    try {
        con = util.connectdb();
        con.setAutoCommit(false);
        st = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,
                ResultSet.CONCUR_UPDATABLE);
        ResultSet rs = st.executeQuery("select * from " + util.dbName
                + ".COFFEES");
        while (rs.next()) {
            float f = rs.getFloat("PRICE");
            rs.updateFloat("PRICE", f * percentage);
            rs.updateRow();
        }
    } catch (SQLException e) {
        e.printStackTrace();
    } catch (ClassNotFoundException e) {

        e.printStackTrace();
    } finally {
        if (st != null) {
            st.close();
            con.close();
        }
    }

}

当我执行此代码块时,下面的堆栈被打印在控制台上。

java.sql.SQLException: Invalid operation for read only resultset: updateFloat
at oracle.jdbc.driver.SQLStateMapping.newSQLException(SQLStateMapping.java:70)
at oracle.jdbc.driver.DatabaseError.newSQLException(DatabaseError.java:131)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:197)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:261)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:269)
at oracle.jdbc.driver.BaseResultSet.updateFloat(BaseResultSet.java:236)
at oracle.jdbc.driver.OracleResultSet.updateFloat(OracleResultSet.java:677)
at tutorial.ModifyResultSet.modifyPrice(ModifyResultSet.java:29)
at tutorial.ModifyResultSet.main(ModifyResultSet.java:15)

任何人都可以帮我修复此错误吗?

1 个答案:

答案 0 :(得分:1)

根据这些链接 http://www.coderanch.com/t/301466/JDBC/databases/Invalid-operation-read-only-resultset http://www.coderanch.com/t/295932/JDBC/databases/updateXXX-function-ResultSet

而不是“select * from”你应该使用“select my_column_name from”语句。 看看它是否有所不同。