0

谁能告诉我如何在 defaulttablemodel 上添加行?我使用结果集从数据库中检索数据并rs.getString()获取它们..而且我希望这个表在我按下按钮后自动更新..

public void table(){

    try{

        rs = stat.executeQuery("SELECT * FROM payments;");

        Vector<String> header = new Vector<String>();

        header.add("PAYMENT"); 
        header.add("AMOUNT");
        header.add("MODIFIER");
        header.add("DATE MODIFIED");

        Vector<Vector<Object>> data = new  Vector<Vector<Object>>();

        while(rs.next()) {

            Vector<Object> row = new Vector<Object>();

            row.add(rs.getString("description"));
            row.add(rs.getString("amount")); 
            row.add(rs.getString("remarks")); 
            row.add(rs.getString("date"));


            dtm.addRow(row);

        } // loop

        dtm.setDataVector(data , header);
        JScrollPane scrollPane = new JScrollPane(table);

        scrollPane.setBounds(0,0,490,250);
        panel.add(scrollPane);
        validate();

    }catch(Exception e){
        System.out.println("Error in table: "+e);
    }//try and catch

}
4

1 回答 1

1

您可以使用dataVector 存储所有结果/行,然后dtm.setDataVector(data , header);在循环之后存储。

更改您的代码

dtm.addRow(row);

data.add(row);

基本上,您的代码必须是

    Vector<Vector<Object>> data = new  Vector<Vector<Object>>();

    while(rs.next()) {

        Vector<Object> row = new Vector<Object>();

        row.add(rs.getString("description"));
        row.add(rs.getString("amount")); 
        row.add(rs.getString("remarks")); 
        row.add(rs.getString("date"));


        data.add(row); // add each result/row to data Vector

    } // loop

    dtm.setDataVector(data , header); // load all the table rows to DefaultTableModel
于 2013-09-29T15:46:59.910 回答