我的目标是使用 JTable 显示数据库中的数据。
参考代码来自:从 ResultSet 填充 JTable 的最简单代码
我修改了代码以适应我的情况。我有一个具有以下方法的类 TopicData:
public DefaultTableModel buildTableModel(){
//open connection
ResultSet rs = null;
Vector<String> columnNames = new Vector<String>();
Vector<Vector<Object>> data = new Vector<Vector<Object>>();
int columnCount = 0;
DBController db = new DBController();
db.setUp("myDatabase");
String dbQuery = "SELECT topicName, topicDate, topicCategory, topicUser FROM topicTable ORDER BY topicDate";
rs = db.readRequest(dbQuery);
try{
ResultSetMetaData metaData = rs.getMetaData();
// names of columns
columnCount = metaData.getColumnCount();
for (int column = 1; column <= columnCount; column++) {
columnNames.add(metaData.getColumnName(column));
}
// data of the table
while (rs.next()) {
Vector<Object> vector = new Vector<Object>();
for (int columnIndex = 1; columnIndex <= columnCount; columnIndex++) {
vector.add(rs.getObject(columnIndex));
}
data.add(vector);
}
}
catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//close connection
db.terminate();
return new DefaultTableModel(data, columnNames);
}
在另一个类 TopicView 中:
private JTable getTable() {
if (table == null) {
TopicData topic= new TopicData();
table = new JTable(topic.buildTableModel());
table.setShowGrid(false);
table.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
table.setBounds(95, 59, 625, 357);
}
return table;
}
我意识到我的表格在每列的顶部没有标题。 http://i.stack.imgur.com/FcnHb.png
因此,我简化了我的 TopicData 以进行故障排除:
public DefaultTableModel testTableModel(){
Vector<String> columnNames = new Vector<String>();
columnNames.add("test1");
columnNames.add("test1");
columnNames.add("test1");
Vector<Vector<Object>> data = new Vector<Vector<Object>>();
Vector<Object>vector = new Vector<Object>();
vector.add("test2");
vector.add("test2");
vector.add("test2");
data.add(vector);
return new DefaultTableModel(data, columnNames);
}
再一次,该表没有标题。“test1”这个词没有出现在表格的任何地方,而“test2”显示了3列。
我对此感到非常困惑,任何帮助将不胜感激。