Я хочу отобразить таблицу базы данных в виде 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 мог иметь следующие функции:
- Показывает данные из базы данных
- Пользователь может редактировать таблицу напрямую, и когда он нажимает кнопку «Сохранить», изменения отражаются в данных базы данных
- Пользователь может вставлять данные напрямую.
- Пользователь может удалять данные напрямую.