[疯狂Java]JDBC:ResultSetMetaData(结果集元数据分析)

1. 描述ResultSet信息的数据——ResultSetMetaData:

    1) MetaData即元数据,即描述其它数据的数据,因此ResultSetMetaData就是描述ResultSet的元数据;

    2) 通常在你对查询结果不了解的情况下可以使用该元数据来了解结果集的记录有几列,每列的类型是啥,每列的名称是啥?


2. 分析ResultSet元数据:

    1) 首先你要获得ResultSetMetaData对象(必定是从属于某个ResultSet对象):ResultSetMetaData ResultSet.getMetaData();

    2) 元数据对象中最常用的三种方法来获取记录的有关信息:都是ResultSetMetaData的对象方法

         i. int getColumnCount(); // 获取列数

         ii. String getColumnName(int column);  // 获取指定列的列名,列索引从1开始计

         iii. int getColumnType(int column);  // 获取指定列的SQL类型,是Types中定义的静态常量

    3) 一般不推荐使用ResultSetMetaData来分析结果集,因为这样分析需要一定的系统开销(底层查询数据库中的元数据然后返回想要的值),因此最好是先了解数据表的具体结构然后直接分析结果集比较好;

    4) 示例:完全依赖ResultSetMetaData来解析结果集

public class Test {
	
	private Connection conn;
	private Statement stmt;
	
	private JFrame jf;
		private JPanel jp;
			private JLabel jl;
			private JTextField jt;
			private JButton jb;
		private JScrollPane jscp; // 显示查询结果的滚动面板
	
	class ExecListener implements ActionListener {

		@Override
		public void actionPerformed(ActionEvent e) {
			// TODO Auto-generated method stub
			if (jscp != null) {
				jf.remove(jscp); // 先删掉原有的结果列表面板
			}
			
			try (
				ResultSet rs = stmt.executeQuery(jt.getText())
			) {
				ResultSetMetaData rsmd = rs.getMetaData();
				Vector<String> colNames = new Vector<>(); // 列名
				Vector<Vector<String>> rows = new Vector<>(); // 行的集合
				
				for (int i = 0; i < rsmd.getColumnCount(); i++) { // 获取列名
					colNames.add(rsmd.getColumnName(i + 1));
				}
				while (rs.next()) {
					Vector<String> v = new Vector<>();
					for (int i = 0; i < rsmd.getColumnCount(); i++) { // 填写rows
						v.add(rs.getString(i + 1));
					}
					rows.add(v);
				}
				
				JTable jtable = new JTable(rows, colNames); // 利用rows和colNames创建一个列表控件
				jscp = new JScrollPane(jtable);
				jf.add(jscp);
				jf.validate(); // 主界面重画一遍
			}
			catch (Exception ex) {
				ex.printStackTrace();
				return ;
			}
		}
		
	}
	
	public void init() {
		try { // 准备连接并获取句柄
			Properties props = new Properties();
			props.load(new FileInputStream("mysql.ini"));
			String driver = props.getProperty("driver");
			String url = props.getProperty("url");
			String user = props.getProperty("user");
			String pass = props.getProperty("pass");
			
			conn = DriverManager.getConnection(url, user, pass);
			stmt = conn.createStatement();
		}
		catch (Exception e) {
			e.printStackTrace();
		}
		
		// 加载主界面
		jf = new JFrame("SQL查询器");
			jp = new JPanel(); jf.add(jp, BorderLayout.NORTH);
				jl = new JLabel("输入查询语句:"); jp.add(jl);
				jt = new JTextField(45); jp.add(jt);
				jb = new JButton("查询"); jp.add(jb);
				
		jt.addActionListener(new ExecListener());
		jb.addActionListener(new ExecListener());
		
		jf.setSize(700, 480);
		jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		jf.setVisible(true);
	}

	public static void main(String[] args) {
		new Test().init();
	}

}


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JDBCJava Database Connectivity)是Java提供的一个进行数据库操作的标准接口。ResultSetJDBC中用于表示查询结果的接口,而ResultSetMetaData是用于描述ResultSet中的结果集元数据的接口。 封装是面向对象编程的一种重要原则,它将数据与操作数据的代码进行了隔离和封装,提高了代码的可维护性和可重用性。在JDBC中,ResultSetResultSetMetaData的封装使得我们可以方便地获取和操作数据库查询的结果。 ResultSet可以通过执行SQL查询语句并将查询结果返回来创建。它提供了一系列的方法用于获取查询结果的数据,例如getString、getInt、getDate等。而ResultSetMetaData则提供了一系列的方法用于获取ResultSet中的元数据,例如getColumnCount、getColumnName、getColumnType等。 通过ResultSet的封装,我们可以方便地遍历查询结果中的每一行数据,并提取需要的字段值。使用ResultSetMetaData的封装,我们可以获取到结果中每一列的元数据信息,例如列名、数据类型、是否可为空等。 这些封装使得我们在使用JDBC进行数据库操作时,能够更加方便地操作结果,减少了繁琐的代码编写。我们可以通过ResultSetResultSetMetaData提供的方法来获取查询结果中的数据和元数据,并根据需要进行处理或展示。封装使得我们的代码更具有可读性和可维护性,并为后续的扩展和优化提供了良好的基础。 总之,JDBCResultSetResultSetMetaData的封装让我们能够更加方便地操作数据库查询结果的数据和元数据,提高了代码的效率和可读性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值