首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JDBC TableModel用于JTable吗?

JDBC TableModel用于JTable吗?
EN

Stack Overflow用户
提问于 2010-02-04 17:46:10
回答 1查看 6.1K关注 0票数 2

我想以JTable的形式显示数据库表。我以前从未使用过JTable,所以我搜索了JTable和TableModel。

通过谷歌搜索,我能够编写我自己的自定义TableModel,它显示存储在

代码语言:javascript
复制
Object[][] data;

现在,我想在JTable中显示我的数据库表数据。我也对此进行了搜索,并对此有了一定的了解,但仍然对AbstractTableModel的实现类应该做什么感到困惑。

以下是自定义TableModel的代码。

代码语言:javascript
复制
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可以具有以下功能:

  1. 显示来自数据库的数据
  2. 用户可以直接编辑表,当他单击“保存”按钮时,所做的更改反映在数据库数据中,
  3. 用户可以直接插入数据。
  4. 用户可以直接删除数据。

G 211

EN

回答 1

Stack Overflow用户

发布于 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中设置的其他筛选器)。

  1. ,我建议一个两步的过程。用户首先单击一个按钮,该按钮将一行添加到表中。输入数据后,用户单击另一个按钮插入数据库(或者您可以将此功能与“保存”按钮中的更新结合起来)。如果主键列不是自动生成的ID.

,则需要允许主键字段对新插入的行可编辑。

为了区分哪些行已经在数据库中,哪些行没有,我建议存储一个新插入行的列表。

如果让用户只选择要在表中显示的某些列,则需要确定如何处理未显示的列(例如。让数据库设置一个默认值,用自动生成的ID填充)。

  1. 可能最好通过在每个行中设置一个复选框来实现这一点,然后当单击" delete“按钮时,它会调用SQL从1和2中提到的主键元数据中删除每个选中的行,并将其从表中删除。

一般考虑因素:

  • 相同的setValueAt方法将用于更新行和插入行,但您需要不同的行为。您希望为更新设置updatedRow,但不要在编辑要插入的行时设置。
  • 将如何处理诸如未满足的约束或无效输入等错误(例如。(数字字段中的“‘abcde”)?
  • SQL注入。
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2201886

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档