3

我正在使用 SwingWorker 使用此处建议的方法通过自定义 TableModel 将数据库中的数据加载到我的 JTable 中:How to fill data in a JTable with database? . 如果我在继续处理 SwingWorker 中的 ResultSet 之前绑定我的 TableModel,我最终会在表模型中得到一个空列表,并且 JTable 会抱怨。如果我在调用 SwingWorker 后绑定模型,我的 JTable 会错过一些由该publish方法触发的回调以更新表中的行。这是我的代码的样子:

class MyTableModel{
 ResultSet rs;
 //Row is an intenral row object that is obtained after processing resultset  
 List<Row> data

 MyTableModel(){
 //initalise the row, rs etc;
 } 

 public void updateData(List<Row> r){
    data.addAll(r);
 }

 //called as a callback by another class that manages the queries
 public void processResults(ResultSet rs){
   new SwingWorker<Void,Row>(){
    doInBackground(){
     //process row by row
     publish(row);
    }
    public void process(List<Row> chunks){
       updateData(chunks);
       fireTableDataChanged();
    }
   }.execute();
 }

}

这就是我现在设置表格模型的方式

MyTableModel m = new MyTableModel();
//pass m as callback to the database manager which invokes processResults() on m
dbm.makeQuery("SELECT bit,pat from bot;",m);
table.setModel(m);
4

1 回答 1

2

首先,我(个人)不会真正fireTableDataChanged()为此使用方法,它需要JTable完全重新绘制本身(包括列)。随着数据集的增长,这将大大增加重绘时间......

public void updateData(List<Row> r){
    int firstRow = getRowCount();
    data.addAll(r);
    int lastRow = getRowCount() - 1;

    fireTableRowsInserted(firstRow, lastRow);

}
于 2012-08-28T04:36:47.427 回答