JAVA基础 之 ResultSetMetaData
程序员文章站
2022-03-02 08:51:05
...
概述:
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.文章反映个人愚见,如有异议欢迎讨论指正
上一篇: web前端开发需要学习哪些技术
推荐阅读
-
java设计模式之模板方法模式详解
-
Java并发实例之CyclicBarrier的使用
-
Java反射之Call stack introspection详解
-
Java concurrency线程池之线程池原理(四)_动力节点Java学院整理
-
Java concurrency线程池之线程池原理(三)_动力节点Java学院整理
-
Java concurrency之AtomicLongArray原子类_动力节点Java学院整理
-
微信公众号开发之设置自定义菜单实例代码【java版】
-
Java concurrency之AtomicLong原子类_动力节点Java学院整理
-
Java concurrency线程池之Callable和Future_动力节点Java学院整理
-
Java面向对象之成员隐藏与属性封装操作示例