根据查询更新JTable显示

JTable的实现是基于MVC的, 所以JTabel的数据显示是一个独立的model的, JTable#setModel(TableModel dataModel)就是来设置model的, 所以你如果想动态显示数据, 你需要实现一个TableModel, 下面以一个User对象为例来说明这个情况!User可能来自你的数据库查询, 也就是一个实体:

class User {
	private String id;
	private String name;
	public User() {
	}
	public User(String id, String name) {
		this.id = id;
		this.name = name;
	}
	public String getId() {
		return id;
	}
	public void setId(String id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
}



class UserTableModel extends AbstractTableModel {
	private static final long serialVersionUID = 1L;
	// 保存一个User的列表
	private List<User> users = new ArrayList<User>();
	// 设置User列表, 同时通知JTabel数据对象更改, 重绘界面
	public void setUsers(List<User> users) {
		this.users = users;
		this.fireTableDataChanged();// 同时通知JTabel数据对象更改, 重绘界面
	}
	public int getColumnCount() {
		return 2;
	}
	public int getRowCount() {
		return users.size();
	}
	// 从list中拿出rowIndex行columnIndex列显示的值
	public Object getValueAt(int rowIndex, int columnIndex) {
		User user = users.get(rowIndex);
		if (columnIndex == 0) {
			return user.getId();
		} else {
			return user.getName();
		}
	}
}


import java.awt.BorderLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.Arrays;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JTable;

public class userjtable {
  public static void main(String args[]) {
    JFrame frame = new JFrame();
    frame.setBounds(100, 100, 500, 375);
    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

    JTable table = new JTable();
    final UserTableModel userTableModel = new UserTableModel();
    userTableModel.setUsers(Arrays.asList(new User("1", "fuxueliang")));
    table.setModel(userTableModel);

    frame.getContentPane().setLayout(new BorderLayout());
    frame.getContentPane().add("Center", table);

    JButton button = new JButton("Change Model");
    button.addActionListener(new ActionListener() {
      public void actionPerformed(ActionEvent e) {
        String current = String.valueOf(System.currentTimeMillis());
        // 注意:这里修改了UserTableModel的list, 这个list可以是你从数据库上查出来的
        userTableModel.setUsers(Arrays.asList(new User("2", current)));
      }
    });
    frame.getContentPane().add("South", button);
    frame.setVisible(true);
  }

}

http://news.qiku.info/blog/3398.html




  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现这个功能的大致思路如下: 1. 创建一个 JTable 对象用来显示数据库中的数据; 2. 创建一个 JButton 对象用来触发查询操作; 3. 在 JButton 的 ActionListener 中编写查询数据库更新 JTable 的代码。 下面是一份示例代码,可以作为参考: ```java import javax.swing.*; import javax.swing.table.DefaultTableModel; import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql.*; public class JTableDemo extends JFrame implements ActionListener { private JButton queryButton; private JTable table; private DefaultTableModel tableModel; private Connection conn; private PreparedStatement stmt; public JTableDemo() { super("JTable Demo"); // 初始化按钮 queryButton = new JButton("查询"); queryButton.addActionListener(this); // 初始化表格 tableModel = new DefaultTableModel(); table = new JTable(tableModel); // 添加组件 JPanel contentPane = new JPanel(new BorderLayout()); contentPane.add(queryButton, BorderLayout.NORTH); contentPane.add(new JScrollPane(table), BorderLayout.CENTER); setContentPane(contentPane); // 连接数据库 try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password"); } catch (Exception e) { e.printStackTrace(); } // 显示窗口 setSize(600, 400); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); setVisible(true); } @Override public void actionPerformed(ActionEvent e) { if (e.getSource() == queryButton) { // 查询数据库 try { stmt = conn.prepareStatement("SELECT * FROM student"); ResultSet rs = stmt.executeQuery(); // 清空表格数据 tableModel.setRowCount(0); // 更新表格数据 while (rs.next()) { Object[] row = new Object[3]; row[0] = rs.getString("id"); row[1] = rs.getString("name"); row[2] = rs.getString("age"); tableModel.addRow(row); } rs.close(); } catch (SQLException ex) { ex.printStackTrace(); } } } public static void main(String[] args) { new JTableDemo(); } } ``` 这份代码中,我们在 actionPerformed 方法中编写了查询数据库更新 JTable 的代码。当用户点击查询按钮时,程序会执行 SQL 语句获取数据库中的数据,并将数据显示JTable 中。需要注意的是,每次查询之前需要清空表格数据,否则会导致重复显示

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值