JTable组件的使用

12 篇文章 0 订阅
3 篇文章 0 订阅

Jtable有两种构造方法
JTable([ ][ ]a,[ ]b);
b是一维数组为列名,a为二维数组,其中{{a1}}中的a1即为一行数据,但在定义初期就限定了数组大小,灵活性不高。
JTable(vector a,vector b);
所以具体详细讲第二种方法,其中b为列名,a为数据,即a为二维集合,也就是a集合里面装着a1,a2,a3集合,如{{a1},{a2},{a3}…},而a1,a2,a3集合中的元素数据与列名是相对应的,也就是在JTable中,一个a1集合即为一行数据。
作用:将数据库中的数据显示在界面上。
注:如果在页面中直接添加Jtable列名将无法添加到页面上,需要以下处理 JTableHeader jTableHeader=jTable.getTableHeader();
getContentPane().add(jTableHeader,BorderLayout.NORTH);
否则就加入滚动条,但是在流布局时加入滚动条是无效的。
简单实例如下

import java.awt.FlowLayout;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Vector;

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

public class VectorJtableDemo extends JFrame {
	public VectorJtableDemo() {

		this.setBounds(100, 100, 300, 200);
		JTable jt = new JTable(this.getDate(), this.getNames());
		JScrollPane js = new JScrollPane(jt);
		this.add(js);
		this.setVisible(true);
	}

	public Vector getNames() {
		Vector name = new Vector();
		name.add("编号");
		name.add("姓名");
		name.add("工作");
		name.add("薪水");
		name.add("部门编号");
		return name;
	}

	public Vector getDate() {
		Vector date = new Vector();
		String driverClass = "oracle.jdbc.driver.OracleDriver";
		String url = "jdbc:oracle:thin:@localhost:1521:orcl";
		try {
			Class.forName(driverClass);
			Connection con = DriverManager.getConnection(url, "scott", "tiger");
			String sql = "select * from emp";
			PreparedStatement ps = con.prepareStatement(sql);
			ResultSet rs = ps.executeQuery();
			while (rs.next()) {
				Vector message = new Vector();
				message.add(rs.getInt(1));
				message.add(rs.getString(2));
				message.add(rs.getString(3));
				message.add(rs.getDouble(4));
				message.add(rs.getInt(6));
				date.add(message);
			}
			rs.close();
			ps.close();
			con.close();
		} catch (Exception e) {
			e.printStackTrace();
		}
		return date;

	}

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

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值