我有一个简单的程序,它使用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();
}
}
});
答案 0 :(得分:1)
您的动作侦听器会创建一个新的表模型,并用这个新的表模型替换JTable的模型。所以你之前添加的TableModelListener仍然会监听旧的表模型,不再使用它。
不要替换表模型,而是更改其内容。或者替换表模型,但将TableModelListener添加到新模型中。