我调查了很多与此相关的不同问题和答案,但找不到似乎有效的一个。
我是 Java 的新手,但有多种不同语言的经验,到目前为止(在我正在试验的上下文中),感觉有点像 VBA,除了必须构建操作/您认为应该已经存在的功能。不过,我想这只是因为我自己缺乏经验。
我正在使用 Netbeans IDE 8.2 和 Java Runtime 1.80。
我创建了包含 jTable 的 jFrame。 jTable 是用这样的数据构建的:
public void showTasks(Boolean removeID) {
ArrayList<Tasks> list = tasksList("SELECT * FROM tasks");
JTable table = jTable1;
DefaultTableModel model = (DefaultTableModel) jTable1.getModel();
Object[] row = new Object[4];
for(int i=0;i<list.size();i++) {
row[0]=list.get(i).getId();
row[1]=list.get(i).getName();
row[2]=list.get(i).getDesc();
row[3]=list.get(i).getDate();
model.addRow(row);
}
// Remove the 'id' column from the table view
if(removeID) { table.removeColumn(table.getColumnModel().getColumn(0)); }
}
这背后的背景不太相关,但本质上 tasksList 是一个将查询应用于 SQL 语句并返回 ArrayList 的函数。我用 4 列构建我的行,然后删除第一列,以便“ID”可用但不可见(此最终操作已通过测试/实验隔离)。
我有另一个代码区域,当单击一行时会打开一个 jDialog,其中可以更新 MySQL 数据库。
问题
我试图加入一个函数调用,以便在关闭 jDialog 时表数据“刷新”。我临时在 jFrame(jTable 所在的位置)中添加了一个按钮来测试/调试此功能。
不过,我似乎无法让它工作。我最接近的实现是重新调用 showTasks(false),但这显然只是添加具有更新数据的行,而不是替换数据集。我不能 100% 确定删除所有行然后重新构建它们是否是“最佳做法”。
由于我是 Java 的新手,并且可能仍然以一种有缺陷的思维方式来看待它,所以我发现很难将任何其他示例应用到我自己的示例中。我似乎也找不到实现 fireTableDataChanged()
的方法。
这肯定是我想多了的一个简单概念吗?
编辑 - 根据以下答案
如果删除所有行并重新添加它们是可以的,那么为什么这样的事情会被认为是不正确的?
public void refreshTasks() {
DefaultTableModel model = (DefaultTableModel) jTable1.getModel();
int row_total = model.getRowCount();
for(int i= row_total -1;i>=0;i--) {
model.removeRow(i);
}
showTasks(false);
}
编辑:调用数据更新的按钮
现在可以正确地(如果不是不正确地)使用以下内容:
private DefaultTableModel parentTable; // To store the parent 'Task' table model
public void setStart(int user,DefaultTableModel table) {
this.txt_taskID.setText(Integer.toString(user)); // Converts the ID to a string
addData(user); // Populates the fields
parentTable = table; // Sets parent TableModel to a variable
}
以上代码在对话框打开时从父 jFrame 调用,并传递表模型和我要编辑的行的“ID”。表格模型存储在 parentTable
中。
还有一个“保存”按钮和一个“取消”按钮。我还没有将它们分开,目前“保存”就是这样做的(SQL 更新等)。根据以下功能,我的“取消”按钮关闭对话框并刷新 jTable:
private void btn_CancelActionPerformed(java.awt.event.ActionEvent evt) {
this.setVisible(false); // Hide the dialog
Menu menu = new Menu(); // for accessing the tasksList function
parentTable.setRowCount(0); // Clears the jTable data
// jTable data is then 'rebuilt' using the new data
ArrayList<Tasks> list = menu.tasksList("SELECT * FROM tasks");
Object[] row = new Object[4];
for(int i=0;i<list.size();i++) {
row[0]=list.get(i).getId();
row[1]=list.get(i).getName();
row[2]=list.get(i).getDesc();
row[3]=list.get(i).getDate();
parentTable.addRow(row);
}
}
最佳答案
I'm not 100% sure if deleting all the rows, then building them back in is 'best practice'.
是的,这可能是最佳实践。
唯一的其他方法是创建一个全新的 TableModel 并使用 setModel() 方法将其添加到表中。这种方法的问题是它会重置您可能已在表格上设置的任何自定义渲染器/编辑器。
从 DefaultTableModel 中删除所有行的最简单方法是使用:
model.setRowCount(0);
关于Java:在子 jDialog 中更新数据后刷新我的 jTable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44242288/