【发布时间】:2015-09-15 07:45:49
【问题描述】:
目前我遇到以下问题:
我像这样从 H2 数据库加载 TableModel 数据:
public static DefaultTableModel loadTableModel(ResultSet rs)
throws SQLException {
// names of columns
Vector<String> columnNames = new Vector<String>();
int columnCount = Definitions.COLUMN_NAMES.length;
for (String string : Definitions.COLUMN_NAMES) {
columnNames.add(string);
}
// data of table
Vector<Vector<Object>> data = new Vector<Vector<Object>>();
while (rs.next()) {
Vector<Object> vector = new Vector<Object>();
for (int columnIndex = 1; columnIndex <= columnCount; columnIndex++) {
if (rs.getObject(columnIndex).getClass() == Integer.class) {
if ((int) rs.getObject(columnIndex) == 0) {
vector.add(null);
} else {
vector.add(rs.getObject(columnIndex));
}
} else {
vector.add(rs.getObject(columnIndex));
}
}
data.add(vector);
}
return new DefaultTableModel(data, columnNames);
}
通过这样做,我将数据库中的data 和columnNames 传递给DefaulTableModel 的构造函数。问题是,并非我的所有列都包含相同的数据类型(似乎默认类型似乎是字符串),所以我需要在创建DefaultTableModel 时直接为所有列设置数据类型。这怎么可能呢?我没有找到稍后更改列类的方法。
如果我创建自己的扩展 DefaultTableModel 的“TableModelClass”,我需要如何创建一个像这样工作的构造函数:
TableModelClass(data, columnNames, columnType)
columnType 应该是包含类类型的向量,例如
String.class、Boolean.class等
【问题讨论】:
标签: java jdbc jtable extends defaulttablemodel