首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用JdbcRowSet对象更新时出现异常

使用JdbcRowSet对象更新时出现异常
EN

Stack Overflow用户
提问于 2014-05-15 09:30:20
回答 1查看 579关注 0票数 1

当我运行下面的程序时,我在更新RowSet时得到以下异常,但scrollable工作正常。默认情况下,JdbcRowSet是可更新和可滚动的吗?

代码语言:javascript
运行
复制
       java.sql.SQLException: ResultSet is not updatable
        at com.sun.rowset.JdbcRowSetImpl.checkTypeConcurrency(Unknown Source)
        at com.sun.rowset.JdbcRowSetImpl.updateString(Unknown Source)
        at JdbcRowSet_Example.<init>(JdbcRowSet_Example.java:66)
        at JdbcRowSet_Example.main(JdbcRowSet_Example.java:77)

代码片段

代码语言:javascript
运行
复制
import com.sun.rowset.JdbcRowSetImpl;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;

import javax.sql.rowset.JdbcRowSet;




public class JdbcRowSet_Example {
    String driver = "oracle.jdbc.driver.OracleDriver";
    String url= "jdbc:oracle:thin:@192.168.1.102:1521:orcl";
    String userName = "scott";
    String passWord = "tiger";

    public JdbcRowSet_Example() throws Exception {
        Class.forName(driver);
        JdbcRowSet jrs = new JdbcRowSetImpl();
        jrs.setCommand("select * from Registration");
        jrs.setUrl(url);
        jrs.setUsername(userName);
        jrs.setPassword(passWord);

        jrs.execute();

        ResultSetMetaData rsmd = jrs.getMetaData();
        int count = rsmd.getColumnCount();
        System.out.println("Number of Columns" + count);



        System.out.println("Scrollable Example");

        jrs.absolute(2);
        for(int i=1; i<=count; i++){
            System.out.print(jrs.getString(i) + "\t" + "\t"+"\t");
            }
        System.out.println();

        System.out.println("Updatable Example");


        jrs.absolute(4);


        jrs.updateString(1, "Reyansh");
        jrs.updateString(2,"Gogula");
        jrs.updateString(3,"Rey_Gogula@hotmail.com");
        jrs.updateRow();
    }

    /**
     * @param args
     */
    public static void main(String[] args) {
        try {
            JdbcRowSet_Example jd = new JdbcRowSet_Example();
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }

}
EN

Stack Overflow用户

发布于 2014-09-11 13:34:49

将查询更改为:从注册中选择注册。*;

我知道这看起来很愚蠢,但它工作得很好!

票数 1
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23667818

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档