我用JAVA的swing创建了一个窗口程序,拖了一个jTable控件在窗体上,怎样把数据库中的内容显示在Table上?

我已经写好了一个类(user),获取了数据库的内容(用户名,密码),并且封装到了一个ArrayList中,初学者,请讲详细点,只要能帮我解决这个问题,我追加到100分,非... 我已经写好了一个类(user),获取了数据库的内容(用户名,密码),并且封装到了一个ArrayList中,初学者,请讲详细点,只要能帮我解决这个问题,我追加到100分,非常感谢!也可以加QQ具体说,我的Q是:395319658 展开
 我来答
泰然还素净的海鸥H
推荐于2016-07-15 · TA获得超过332个赞
知道小有建树答主
回答量:211
采纳率:0%
帮助的人:134万
展开全部
public class T extends JFrame {

private static final long serialVersionUID = 1L;
private JPanel jPanel = null;
private JTextField jTextField = null;
private JTextField jTextField1 = null;
private JButton jButton = null;
private JButton jButton1 = null;
private JButton jButton2 = null;
private JTable jTable = null;
private DefaultTableModel tableModel = null;

private JPanel getJPanel() {
if (jPanel == null) {
JLabel jLabel1 = new JLabel();
jLabel1.setBounds(new Rectangle(30, 50, 80, 25));
jLabel1.setText("请输入ISBN:");
JLabel jLabel = new JLabel();
jLabel.setBounds(new Rectangle(30, 20, 80, 25));
jLabel.setText("请输入书名:");
jPanel = new JPanel();
jPanel.setLayout(null);
jPanel.setPreferredSize(new Dimension(1, 120));
jPanel.add(jLabel);
jPanel.add(jLabel1);
jPanel.add(getJTextField());
jPanel.add(getJTextField1());
jPanel.add(getJButton());
jPanel.add(getJButton1());
jPanel.add(getJButton2());
}
return jPanel;
}

private JTextField getJTextField() {
if (jTextField == null) {
jTextField = new JTextField();
jTextField.setBounds(new Rectangle(120, 20, 140, 25));
}
return jTextField;
}

private JTextField getJTextField1() {
if (jTextField1 == null) {
jTextField1 = new JTextField();
jTextField1.setBounds(new Rectangle(120, 50, 140, 25));
}
return jTextField1;
}

private JButton getJButton() {
if (jButton == null) {
jButton = new JButton();
jButton.setBounds(new Rectangle(270, 20, 60, 25));
jButton.setText("显示");
jButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
/* 修改处 */
}
});
}
return jButton;
}

private JButton getJButton1() {
if (jButton1 == null) {
jButton1 = new JButton();
jButton1.setBounds(new Rectangle(270, 50, 60, 25));
jButton1.setText("显示");
jButton1.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
/* 修改处 */
}
});
}
return jButton1;
}

private JButton getJButton2() {
if (jButton2 == null) {
jButton2 = new JButton();
jButton2.setBounds(new Rectangle(240, 80, 90, 30));
jButton2.setText("显示全部");
jButton2.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
/*
* 修改处此处只要改下面一行,换成从数据库读就行
* 应该在DAO层加一个查询全部的方法
* public List<Titles> getAll();具体实现自己写。
* 把114行的代码改成:List<Titles> lists = new TitleDaoImpl().getAll();
* */
List<Titles> lists = Titles.list();
// 将表行数设为0行,防止异常
tableModel.setRowCount(0);
for (int i = 0; i < lists.size(); i++) { // 当每有一个Titles对象就添加一行
tableModel.addRow(new Object[] {});
}
Titles instance = null;
Object obj = null;
Object name = null;
for (int i = 0; i < tableModel.getRowCount(); i++) { // 行循环
instance = lists.get(i); // 为当前Titles对象赋值
for (int j = 0; j < tableModel.getColumnCount(); j++) {
name = tableModel.getColumnName(j);
if (name.equals("ISBN")) {
obj = instance.getISBN();
} else if (name.equals("title")) {
obj = instance.getTitle();
} else if (name.equals("publisher")) {
obj = instance.getPublisher();
} else if (name.equals("date")) {
obj = instance.getDate();
} else if (name.equals("price")) {
obj = instance.getPrice();
} else {
obj = "";
}
tableModel.setValueAt(obj, i, j);
}
}
}
});
}
return jButton2;
}

private JPanel getJPanel1() {
JScrollPane jScrollPane = new JScrollPane();
jScrollPane.setViewportView(getJTable());
JPanel panel = new JPanel(new BorderLayout());
panel.add(jScrollPane, BorderLayout.CENTER);
return panel;
}

private JTable getJTable() {
if (jTable == null) {
// 获得Titles类里的字段,一个字段在JTable中应该表现为一列
Field[] fields = Titles.class.getDeclaredFields();
// 将字段名保存为列名数组为DefaultTableModel所用
Object[] columnNames = new Object[fields.length];
for (int i = 0; i < fields.length; i++) {
columnNames[i] = fields[i].getName();
}
tableModel = new DefaultTableModel(columnNames, 0);
jTable = new JTable(tableModel);
}
return jTable;
}

public static void main(String[] args) {
SwingUtilities.invokeLater(new Runnable() {
public void run() {
T thisClass = new T();
thisClass.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
thisClass.setVisible(true);
}
});
}

public T() {
super();
setSize(580, 475);
getContentPane().add(getJPanel(), BorderLayout.SOUTH);
getContentPane().add(getJPanel1(), BorderLayout.CENTER);
}

}
刮刮清风
2012-06-06 · TA获得超过608个赞
知道小有建树答主
回答量:88
采纳率:100%
帮助的人:85.8万
展开全部
Arraylist 数据 要转换成Vector保存数据,Vector这个容器线程安全.
然后构造一个DefaultTableModel 设置 数据 和表格 头部, 可以用构造,也可以用set
//定义
JTable table;
DefaultTableModel model;
Vector<Vector<Object>> users = new Vector<Vector<Object>>();

//操作
users = new UserDaoImp().getAllUser();
model = new DefaultTableModel(users, makeColumn()) {
public boolean isCellEditable(int row, int column) {
return false;
}
};
table = new JTable(model);
JScrollPane userList = new JScrollPane(table);//table放到一个滚动的JScrollPane,表格可以下拉
JPanel userPanel = new JPanel(new BorderLayout()); //用户列表表格面板
userPanel.add(userList);//添加滑动面板到 用户面板中
// 返回 表格的头部
public Vector<String> makeColumn() {
Vector<String> head = new Vector<String>();
head.add("账号");
head.add("姓名");
head.add("年龄");
head.add("性别");
head.add("在线状态");
head.add("账号状态");
head.add("地址");
head.add("注册时间");
return head;
}
更多追问追答
追问
那List怎样转为Vector呢?
追答
写一个方法,  List2Vector()
private Vector> transformList2Vector(Book bookBean) {
List bookList = bookDao.serachBook(bookBean);

Vector> tmp = new Vector>();
Vector book;
for (Book b : bookList) {
book = new Vector();
book.add(b.getBookCode());
book.add(b.getBookName());
book.add(b.getAuthor());
book.add(b.getPublisher());
book.add(b.getPublish_Date());
book.add(b.getPrice());
tmp.add(book);
}
return tmp;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友845f74e61
2012-06-11 · TA获得超过6929个赞
知道大有可为答主
回答量:4050
采纳率:50%
帮助的人:1567万
展开全部
嗯,明天给你弄个例子,你看看

你看一下这个。
-------------------------------------------

import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.ArrayList;
import java.util.List;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableColumnModel;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableColumn;

public class AppDemo extends JFrame implements ActionListener {
private JTable table;
private DefaultTableModel model = null;
private String[] columns = { "no", "name", "age", "email" };
private DefaultTableColumnModel columnModel = new DefaultTableColumnModel();
private TableColumn column = null;

public AppDemo() {
getContentPane().setLayout(null);

JScrollPane scrollPane = new JScrollPane();
scrollPane.setBounds(12, 46, 418, 217);
getContentPane().add(scrollPane);
model = new DefaultTableModel(columns, 0);
table = new JTable(model);
scrollPane.setViewportView(table);

JButton btnNewButton = new JButton("New button");
btnNewButton.setBounds(22, 13, 93, 23);
btnNewButton.addActionListener(this);
getContentPane().add(btnNewButton);

// table.getColumn(0).setWidth(80);
// table.getColumn(1).setWidth(120);
// table.getColumn(2).setWidth(60);
// table.getColumn(3).setWidth(100);
setDefaultCloseOperation(EXIT_ON_CLOSE);
setSize(450, 300);
setVisible(true);
}

public static void main(String[] args) {
new AppDemo();
}

public void actionPerformed(ActionEvent actionevent) {
List<User> list = new ArrayList<User>();
for (int i = 1; i <= 20; i++) {
User user = new User();
user.no = i;
user.name = "name" + i;
user.age = i * 2;
user.email = "name@163.com";
list.add(user);
}
for (int i = 0; i < list.size(); i++) {
User user = list.get(i);
model.addRow(user.toArray());
}
}
}

class User {
public int no = 0;
public String name = null;
public int age = 0;
public String email = null;

public Object[] toArray() {
return new Object[] { no, name, age, email };
}

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
心事诚心技能I
2012-06-07
知道答主
回答量:27
采纳率:0%
帮助的人:9.2万
展开全部
连接数据库。 然后把数据循环输出到界面上
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
神魔鬼怪妖佛仙
2012-06-07 · 超过28用户采纳过TA的回答
知道答主
回答量:121
采纳率:0%
帮助的人:87.4万
展开全部
楼上讲的很详细了, 另外,用数组和List当数据容器也可以.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式