Java JTable从数据库中填充,但未显示

Java JTable从数据库中填充,但未显示,java,swing,jtable,Java,Swing,Jtable,我已经从数据库中填充了JTable。但这张桌子并没有出现。我想不出代码有什么问题。我不明白问题是在于布局还是从数据库检索数据的代码块。我也没有收到任何异常消息。我添加了frame.getContentPane.addscroll、BorderLayout.CENTER;在代码中,仍然无法找到表。请看所附的图片,我得到什么 将JTable添加到框架中,然后将其添加到JScrollPane中,但决不将JScrollPane添加到anything中 组件只能驻留在单个容器中,因此当您执行JScroll

我已经从数据库中填充了JTable。但这张桌子并没有出现。我想不出代码有什么问题。我不明白问题是在于布局还是从数据库检索数据的代码块。我也没有收到任何异常消息。我添加了frame.getContentPane.addscroll、BorderLayout.CENTER;在代码中,仍然无法找到表。请看所附的图片,我得到什么

将JTable添加到框架中,然后将其添加到JScrollPane中,但决不将JScrollPane添加到anything中

组件只能驻留在单个容器中,因此当您执行JScrollPane scroll=new JScrollPanetable;,您正在从帧中删除JTable

添加frame.getContentPane.addscroll、BorderLayout.CENTER;创建JScrollPane之后

您也从不将TableModel应用于JTable


我已经按照你的建议添加了代码,但仍然没有得到表。请帮忙!!!实际上,它确实可以工作,但您从未将TableModel应用于JTable,因此它显示一个空的table1-crossposted:。退出交叉发布。花时间回答一个问题却发现它已经在另一个论坛上得到了回答,这是很烦人的。
import java.awt.EventQueue;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

import javax.swing.JFrame;
import javax.swing.JScrollPane;

import java.awt.BorderLayout;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;

import controller.DB_con;

public class Jtable {

    private JFrame frame;
    private JTable table;
    String[] columnNames = {"ID", "name", "username", "contact", "GENDER"};

    /**
     * Launch the application.
     */
    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {
            public void run() {
                try {
                    Jtable window = new Jtable();
                    window.frame.setVisible(true);
                } catch (Exception e) {
                    e.printStackTrace();
                    System.out.println(e.toString());
                }
            }
        });
    }

    /**
     * Create the application.
     */
    public Jtable() {
        initialize();
    }

    /**
     * Initialize the contents of the frame.
     */
    private void initialize() {
        frame = new JFrame();
        frame.setBounds(100, 100, 450, 300);
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.getContentPane().setLayout(new BorderLayout(0, 0));

        table = new JTable();
        frame.getContentPane().add(table, BorderLayout.CENTER);
        DefaultTableModel model = new DefaultTableModel();
        model.setColumnIdentifiers(columnNames);

        table.setAutoResizeMode(JTable.AUTO_RESIZE_ALL_COLUMNS);
        table.setFillsViewportHeight(true);
        JScrollPane scroll = new JScrollPane(table);
        frame.getContentPane().add(scroll, BorderLayout.CENTER);
        scroll.setHorizontalScrollBarPolicy(
        JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
        scroll.setVerticalScrollBarPolicy(
        JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED);

        try
        {
            Connection sqlCon = DB_con.getSQLConnection();
            PreparedStatement ps = sqlCon.prepareStatement("select id,name,username,contact,gender from temp_tbl");

            int i = 0;
            ResultSet rs = ps.executeQuery();
            while(rs.next())
            {
                String id = rs.getString("id");
                String name = rs.getString("name");
                String username = rs.getString("username");
                String contact = rs.getString("contact");
                String gender = rs.getString("gender");
                model.addRow(new Object[]{id, name, username, contact, gender});
                i++;
            }
        }
        catch(Exception ex)
        {
            System.out.println(ex.toString());
        }

    }

}
table.setModel(model);
frame.getContentPane().add(scroll, BorderLayout.CENTER);