JAVA基础 之 ResultSetMetaData

概述:

    1.ResultSetMetaData包含了查询后的结果集的相关信息

    2.通过rs.getMetaData();来创建

    3.可以写出通用型遍历结果集程序(不知道结果集结构情况下)

       步骤:

       1.先获得结果集字段或者字段别名

       2.遍历封装结果集(可以根据字段自行选择封装哪些数据)

 

package com.cxy.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @author cxy
 */
public class ResultSetMetaDataTest
{
	public static void main(String[] args) throws Exception
	{
		Class.forName("com.mysql.jdbc.Driver");
		try
		(
			Connection con=DriverManager.getConnection("jdbc:mysql://localhost/dbtest", "root", "root");
			PreparedStatement pstmt=con.prepareStatement("select id_ as 主键,name_ as 姓名,sex as 性别 from t_student", 
						 ResultSet.TYPE_SCROLL_SENSITIVE,
						 ResultSet.CONCUR_UPDATABLE);
			ResultSet rs=pstmt.executeQuery();
		)
		{
			ResultSetMetaData rsm=rs.getMetaData();
			System.out.println("t_student表有几个字段?"+rsm.getColumnCount());
			System.out.println("第一个字段所在表?"+rsm.getTableName(1));
			System.out.println("========================");
			
			//遍历一个不知道结构的表
			System.out.println("通用型遍历结果集:");
			System.out.println("1.获得所有的列名");
			int colNum=rsm.getColumnCount();
			String[] colName=new String[colNum]; //字段名
			String[] colLabel=new String[colNum]; //别名
			for(int i=1;i<=colNum;i++)
			{
				colName[i-1]=rsm.getColumnName(i);
				colLabel[i-1]=rsm.getColumnLabel(i);
			}
			System.out.println(Arrays.asList(colName));
			System.out.println(Arrays.asList(colLabel));
			System.out.println("------------------------");
			System.out.println("2.遍历并封装");
			//把结果集封装成List<Map<String,String>>
			List<Map<String,String>> dbData=new ArrayList<>();
			while(rs.next())
			{
				Map<String,String> one = new HashMap<String, String>();
				for(int i=1;i<=colNum;i++)
				{
					one.put(colLabel[i-1], rs.getString(i));
				}
				dbData.add(one);
			}
			//System.out.println(dbData);
			for(Map<String,String> one : dbData)
			{
				System.out.println(one);
			}
		}catch(SQLException e)
		{
			System.out.println("数据库操作出现异常");
		}
	}

}

 

结果截图:



 

相关连接:

《Java基础 之 ResultSet》

《JAVA基础 之 JDBC事务》

 

声明:

1.原创文章,转载请标明并加本文连接。

2.文章反映个人愚见,如有异议欢迎讨论指正

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值