如何通过双击正确删除JTable中的行?

时间:2017-05-21 08:03:38

标签: java swing jtable

大家下午好,我正在尝试学习java编程,然后当我学习JTable时,我遇到了一些我不知道为什么会遇到问题的问题。

所以,我想要做的是当我双击JTable中名为TableGejala的行时,我双击的行将转移到另一个名为TableAturan的JTable中,之后我在TableGejala中双击的行将被删除。对于从TableGejala传输行到TableAturan的部分,当我双击该行时成功传输,但它没有删除TableGejala中的正确行。它不删除我单击的行,而是删除它下面的行。

有关详细信息,这是我创建TableGejala的代码:

private void getTableGejala() {
        while(tabel2.getRowCount() > 0){
            for(int i=0;i < tabel2.getRowCount();i++){
                tabel2.removeRow(i);
            }
        }

        tabel2.addColumn("ID Gejala");
        tabel2.addColumn("Nama Gejala");

        TabelGejala.setModel(tabel2);
        TabelGejala.setAutoResizeMode(TabelGejala.AUTO_RESIZE_ALL_COLUMNS);
    }

然后这是我从MySQL获取数据表的代码:

    private void loadDataGejala(Boolean baru){
    tabel2.getDataVector().removeAllElements();

    try {
        java.sql.Connection konek = (Connection) Koneksi.KoneksiDB.getConnection();
        java.sql.Statement konek_statement = konek.createStatement();
        String query_bukaTabel = "";
        if(baru){
            query_bukaTabel = "select id_gejala,nama_gejala from gejala";
        }
        else{
            String idPkt = FieldID.getText();
            query_bukaTabel = "select gejala.id_gejala,gejala.nama_gejala from gejala where gejala.id_gejala not in(select id_gejala from aturan2 where id_penyakit='"+idPkt+"')";
        }

        java.sql.ResultSet line_result = konek_statement.executeQuery(query_bukaTabel);
        while (line_result.next()) {
            Object[] getO = new Object[2];
            getO[0] = line_result.getString("id_gejala");
            getO[1] = line_result.getString("nama_gejala");
            tabel2.addRow(getO);
        }
        line_result.close();
        konek_statement.close();
    }catch (Exception e) {} 
}

这是我传输行并删除行的代码:

    private void TabelGejalaMousePressed(java.awt.event.MouseEvent evt) {                                         

    if (evt.getClickCount()>=2){
        int col = 0;
        int row = 0;
        row = TabelGejala.rowAtPoint(evt.getPoint());
        col = TabelGejala.columnAtPoint(evt.getPoint());
        String col1 = (String)TabelGejala.getValueAt(row, 0);
        String col2 = (String)TabelGejala.getValueAt(row, 1);
        DefaultTableModel model = (DefaultTableModel) TabelAturan.getModel(); 
        DefaultTableModel old = (DefaultTableModel) TabelGejala.getModel();
        old.removeRow(row);
        model.addRow(new Object[]{col1, col2, 0});
        TabelAturan.requestFocus();
        TabelAturan.setRowSelectionInterval(TabelAturan.getRowCount()-1,TabelAturan.getRowCount()-1);        
        TabelAturan.editCellAt(TabelAturan.getRowCount()-1,2);
    }
}

这是我的问题的屏幕截图:

Before Double Clicked

After Double Clicked

哪个部分使我的输出得到错误的行被删除?请帮助我,并提前感谢您的任何帮助,即使是阅读我的问题:)

1 个答案:

答案 0 :(得分:1)

首先在第一个表(TabelGejala)中禁用单元格可编辑属性,以确保正确删除行。我使用以下代码实现了这一点: -

//instance table model
    DefaultTableModel tableModel = new DefaultTableModel(new Object[][]{},
            new String[]{
                "ID Gejala", "Nama Gejala"
            }) {

        @Override
        public boolean isCellEditable(int row, int column) {
            //all cells false
            return false;
        }
    };

    TabelGejala.setModel(tableModel);

然后使用jtable.getselectedrow()和jtable.getselectedcolumn()从表中获取值。将所需值添加到第二个表后,只需删除所选行。这是从您的代码派生的代码: -

private void TabelGejalaMousePressed(java.awt.event.MouseEvent evt) {                                         
    // TODO add your handling code here:
    if (evt.getClickCount() >= 2) {

        DefaultTableModel model = (DefaultTableModel) TabelAturan.getModel();
        DefaultTableModel old = (DefaultTableModel) TabelGejala.getModel();
        model.addRow(new Object[]{TabelGejala.getValueAt(TabelGejala.getSelectedRow(), 0), TabelGejala.getValueAt(TabelGejala.getSelectedRow(), 1), 0});
        old.removeRow(TabelGejala.getSelectedRow());

        TabelAturan.requestFocus();
        TabelAturan.setRowSelectionInterval(TabelAturan.getRowCount() - 1, TabelAturan.getRowCount() - 1);
        TabelAturan.editCellAt(TabelAturan.getRowCount() - 1, 2);
    }
}