我正在为我的12年级IT课执行实践评估任务。我正在努力用代码在GUI中填充我的jTable(来自swing控件)。我正在使用Netbeans作为IDE。数据库使用jdbc:odbc网桥连接。此代码在我的项目的Java类中。
**请注意,我在编码方面相对缺乏经验
这是我当前拥有的代码(但在我的jtable中没有任何输出)如果您可以修复它,请说明您的操作,或者您可以给我可以运行的代码:)
db.setConnection();
Statement stmt = null;
try {
con = DriverManager.getConnection("jdbc:odbc:Driver={Microsoft Access Driver (*.mdb, *.accdb)}"
+ ";DBQ=src/TheChangeProjectDB.accdb");
stmt = con.createStatement();
} catch (SQLException ex) {
JOptionPane.showMessageDialog(null, "Error: " + ex);
}
String sql = "SELECT * FROM KanyisaLearners";
try {
ResultSet rs = stmt.executeQuery(sql);
ResultSetMetaData md = rs.getMetaData();
int columns = md.getColumnCount();
for (int i = 1; i <= columns; i++) {
columnNames.addElement(md.getColumnName(i));
}
while (rs.next()) {
Vector row = new Vector(columns);
for (int i = 0; i <= columns; i++) {
row.addElement(rs.getObject(i));
}
data.addElement(row);
}
rs.close();
stmt.close();
} catch (Exception e) {
System.out.println(e);
}
JTable table = new JTable(data, columnNames);
JScrollPane scrollPane = new JScrollPane(table);
getContentPane().add(scrollPane);
JPanel buttonPanel = new JPanel();
getContentPane().add(buttonPanel, BorderLayout.SOUTH);
KanyisaHoofskerm frame = new KanyisaHoofskerm();
frame.setDefaultCloseOperation(EXIT_ON_CLOSE);
frame.pack();
frame.setTitle("Learners");
frame.setVisible(true);
给出此行:
JScrollPane scrollPane = new JScrollPane(table);
getContentPane().add(scrollPane); // your class extends from JFrame?
JPanel buttonPanel = new JPanel();
getContentPane().add(buttonPanel, BorderLayout.SOUTH);
然后是这个:
KanyisaHoofskerm frame = new KanyisaHoofskerm(); // new frame local variable
frame.setDefaultCloseOperation(EXIT_ON_CLOSE);
...
frame.setVisible(true);
[我强烈怀疑您的课程是从您要添加表格的JFrame扩展的。如果是这样,则您不会使其可见,而是会显示一个新的frame
局部变量。因此,至少在我看来,根本没有显示表格。
如果是这种情况,请查看this question with the same problem和Extends JFrame vs. creating it inside the the program主题。
关于您的代码进行数据库调用:
您的代码在添加行时给出异常。通过使用描述符而不是使用索引来更改代码。
while (rs.next()) {
Vector row = new Vector(columns);
for (int i = 0; i < columns; i++) {
row.addElement(rs.getObject(columnNames.get(i)));
}
data.addElement(row);
}