我想显示一个数据库表作为JTable。我从来没有使用过JTable,所以我使用JTable和TableModel。用于Java中JTable的JDBC TableModel?
随着那google搜索,我可以写我自己的自定义的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中可以有follwing特点:
- 它显示数据库中的数据
- 用户可以直接编辑表,他点击时在“保存”按钮上,更改反映在数据库数据中
- 用户可以直接插入数据。
- 用户可以直接删除数据。
你在哪里给你最后发表的工作示例。 – camickr
昨天你问了几乎相同的问题:http://stackoverflow.com/questions/2192764/how-to-fill-data-in-a-jtable-with-database – sateesh
Yatendra - 看看我昨天的例子问题并告诉我你卡在哪里,我会尽力给你一些指示。 – Adamski