我想以JTable的形式显示数据库表。我以前从未使用过JTable,所以我搜索了JTable和TableModel。
通过谷歌搜索,我能够编写我自己的自定义TableModel,它显示存储在
Object[][] data;现在,我想在JTable中显示我的数据库表数据。我也对此进行了搜索,并对此有了一定的了解,但仍然对AbstractTableModel的实现类应该做什么感到困惑。
以下是自定义TableModel的代码。
public abstract class AbstractPOLDATTableModel extends AbstractTableModel {
protected boolean DEBUG = false;
private String[] columnNames;
private Object[][] data;
protected AbstractPOLDATTableModel(String[] columnNames, Object[][] data) {
this.columnNames = columnNames;
this.data = data;
}
public int getColumnCount() {
return columnNames.length;
}
public int getRowCount() {
return data.length;
}
@Override
public String getColumnName(int col) {
return columnNames[col];
}
public Object getValueAt(int row, int col) {
return data[row][col];
}
@Override
public Class getColumnClass(int c) {
return getValueAt(0, c).getClass();
}
@Override
public boolean isCellEditable(int row, int col) {
if (col < 2) {
return false;
} else {
return true;
}
}
@Override
public void setValueAt(Object value, int row, int col) {
if (DEBUG) {
System.out.println("Setting value at " + row + "," + col
+ " to " + value
+ " (an instance of "
+ value.getClass() + ")");
}
data[row][col] = value;
fireTableCellUpdated(row, col);
if (DEBUG) {
System.out.println("New value of data:");
printDebugData();
}
}
private void printDebugData() {
int numRows = getRowCount();
int numCols = getColumnCount();
for (int i=0; i < numRows; i++) {
System.out.print(" row " + i + ":");
for (int j=0; j < numCols; j++) {
System.out.print(" " + data[i][j]);
}
System.out.println();
}
System.out.println("--------------------------");
}
}现在,如何更改上面的代码,使我的JTable可以具有以下功能:
G 211
发布于 2010-02-04 23:37:49
我假设您已经按照Adamski在上一个问题中的建议实现了1。另外,正如Sanoj所建议的,更改为使用某种列表来存储数据。
要支持2-4,您必须确保从数据库中提取的数据仅来自一个表,并且不涉及任何派生数据(例如。聚合,column1 + column2)。如果要让用户筛选行,则需要跟踪where子句。在每个行中存储另一个行(我们称之为updatedRow),它表示用户使用GUI进行的更新。一旦对行进行了任何更新,该字段就需要填充包含更新数据的新行。单击"Save“时,使用非空updatedRow运行对所有行的update查询,用updatedRow中的数据更新数据库,这些数据与原始行中的数据不匹配(如果用户将数据更改回原来的方式,则不要更新)。您还可能有另一个“撤消更新”按钮,它用非空的updatedRow.填充表中所有行的原始数据。
我强烈建议您在构成主键的字段上存储其他元数据,并防止更改这些字段,因为对这些列的更新可能很昂贵(因为它们可能是索引的,并且可能附加了一些RI约束)。这应该通过使这些列不可编辑来反映在GUI中。更新中的where子句将只使用这些字段,而不是所有字段(您仍然需要用户在1中设置的其他筛选器)。
,
,则需要允许主键字段对新插入的行可编辑。
为了区分哪些行已经在数据库中,哪些行没有,我建议存储一个新插入行的列表。
如果让用户只选择要在表中显示的某些列,则需要确定如何处理未显示的列(例如。让数据库设置一个默认值,用自动生成的ID填充)。
一般考虑因素:
https://stackoverflow.com/questions/2201886
复制相似问题