Java JTable从数据库中填充,但未显示
我已经从数据库中填充了JTable。但这张桌子并没有出现。我想不出代码有什么问题。我不明白问题是在于布局还是从数据库检索数据的代码块。我也没有收到任何异常消息。我添加了frame.getContentPane.addscroll、BorderLayout.CENTER;在代码中,仍然无法找到表。请看所附的图片,我得到什么 将JTable添加到框架中,然后将其添加到JScrollPane中,但决不将JScrollPane添加到anything中 组件只能驻留在单个容器中,因此当您执行JScrollPane scroll=new JScrollPanetable;,您正在从帧中删除JTable 添加frame.getContentPane.addscroll、BorderLayout.CENTER;创建JScrollPane之后 您也从不将TableModel应用于JTableJava JTable从数据库中填充,但未显示,java,swing,jtable,Java,Swing,Jtable,我已经从数据库中填充了JTable。但这张桌子并没有出现。我想不出代码有什么问题。我不明白问题是在于布局还是从数据库检索数据的代码块。我也没有收到任何异常消息。我添加了frame.getContentPane.addscroll、BorderLayout.CENTER;在代码中,仍然无法找到表。请看所附的图片,我得到什么 将JTable添加到框架中,然后将其添加到JScrollPane中,但决不将JScrollPane添加到anything中 组件只能驻留在单个容器中,因此当您执行JScroll
我已经按照你的建议添加了代码,但仍然没有得到表。请帮忙!!!实际上,它确实可以工作,但您从未将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);