概述:
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("数据库操作出现异常");
}
}
}
结果截图:
相关连接:
声明:
1.原创文章,转载请标明并加本文连接。
2.文章反映个人愚见,如有异议欢迎讨论指正