日期:2014-05-20  浏览次数:20778 次

使用TableModel,修改Table数据以后抛出异常
我将TableModel用来封装JDBC里面的ResultSet,传入ResultSet后,将生成的Model对象用于Table,这样使Table显示MySQL传回来的查找结果。我的SQL语句是
SQL code
select Number, Band_Name, Model, OS, Price,  Available from tb_phone where ......

查找的条件的列名只是表的一部分,现在Table显示一切正常,但是如果双击Table数据进行修改,那么会抛出异常,如下:
SEVERE: null
com.mysql.jdbc.NotUpdatable: Result Set not updatable.This result set must come from a statement that was created with a result set type of ResultSet.CONCUR_UPDATABLE, the query must select only one table, can not use functions and must select all primary keys from that table.
我在TableModel里面重写的setVlueAt()方法如下:
Java code

public void setValueAt(Object aValue, int row, int colum) {
        try {
            //结果集定位到对应的行数
            rs.absolute(row + 1);
            //修改单元格对应的值
            rs.updateObject(row + 1, aValue);
            //提交修改
            rs.updateRow();
            //触发单元格的修改时间
            fireTableCellUpdated(row, colum);
        } catch (SQLException ex) {
            Logger.getLogger(ResultSetTableModel.class.getName()).log(Level.SEVERE, null, ex);
        }
    }


所以不知道该怎么做?
现在MySQL里面的表有主键,就是Number。其他的约束条件则都是非空

------解决方案--------------------
你的statement必须如下定义:
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);