用来自MS Access数据库的数据填充JTable的代码

问题描述 投票:0回答:2

我正在为我的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);
java swing ms-access jdbc jtable
2个回答
1
投票

给出此行:

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 problemExtends JFrame vs. creating it inside the the program主题。

关于您的代码进行数据库调用:


0
投票

您的代码在添加行时给出异常。通过使用描述符而不是使用索引来更改代码。

 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);
    }
© www.soinside.com 2019 - 2024. All rights reserved.