为什么在使用组合框actionListener后没有执行tableModelListener代码

时间:2014-03-22 20:41:57

标签: java database swing jtable actionlistener

我有一个简单的程序,它使用JTable显示数据库的表。 我有一个组合框,列出所有可用的表和一个actionListener,每次更改时都会将模型设置为表。这可以按预期工作。 我得到的问题是,当选择一个表时,程序永远不会到达tableModelListener的代码,因此不会更新数据库。

如果程序输入了某些代码块,并且一旦激活了组合框actionListener,程序就永远不会进入表模型监听器,我会通过弹出消息进行一些调试。

以下是大部分代码。

classes.addActionListener(new ActionListener(){

        @Override
        public void actionPerformed(ActionEvent ev) {
            JComboBox cb = (JComboBox)ev.getSource();
            classname =(String)cb.getSelectedItem();

            String genQuery="select * from "+classname;
            String query = genQuery ;


            //adding info from databae to table/
            ResultSet rs=null;
            try {
                rs = stmt.executeQuery(query);
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            table.setModel(DbUtils.resultSetToTableModel(rs));


        }               

    });

//

//update database
    table.getModel().addTableModelListener(new TableModelListener() {

        @Override
        public void tableChanged(TableModelEvent e) {
            //catch events
            JOptionPane.showMessageDialog(null,"inside table listener");
            int row = e.getFirstRow();  
            int column = e.getColumn();  
            TableModel model = (TableModel)e.getSource();  
            Object data = model.getValueAt(row, column); 
            JOptionPane.showMessageDialog(null, "row: "+ row+" column: "+column+" data "+data);

            String dt = (String)data;
            int val=(Integer) null;
            if(dt.equals("true"))
                val=1;
            if(dt.equals("false"))
                val=0;


            Object student = model.getValueAt(row, 1);
            String stud = (String)student;
            String colname =table.getColumnName(column);



            String edit="update "+classname+" set "+colname+" = ? where studentName= ?";

            try {
                conn.setAutoCommit(false);
                PreparedStatement updateinfo = conn.prepareStatement(edit);


                updateinfo.setInt(1, val);
                updateinfo.setString(2, stud);
                updateinfo.executeUpdate();
                conn.commit();
                JOptionPane.showMessageDialog(null, stud+" has been updated.");
            } catch (SQLException e2) {
                // TODO Auto-generated catch block
                e2.printStackTrace();
            }

        }



    });

1 个答案:

答案 0 :(得分:1)

您的动作侦听器会创建一个新的表模型,并用这个新的表模型替换JTable的模型。所以你之前添加的TableModelListener仍然会监听旧的表模型,不再使用它。

不要替换表模型,而是更改其内容。或者替换表模型,但将TableModelListener添加到新模型中。