元数据:描述数据的数据,ResultSetMetaData是描述ResultSet的元数据对象,从它可以得到数据集有多少了,每一列的列名。。。

ResultSetMetaData可以通过ResultSet类的getMetaData()获得。

ResultSetMetaData中的方法:

  ->getColumnCount():获取数据集有多少列

  ->getColumnLabel(int column):获取指定列的列名,索引从1开始

步骤:

1、利用sql进行查询,得到结果集,查询时应该给出列的别名,别名要和类的对象的属性名对应;

2、利用反射创建实体类的对象;

3、获取结果集的列的别名;

4、再获取结果集中每一列的值,结合步骤3得到一个Map,键为列名,值为对应的值;

5、利用反射给实体对象的属性赋值。

 public <T> T get(Class<T> clazz, String sql,Object ... args){
T entity = null;
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null; try {
//1、进行sql查询,获取resultSet对象
connection = jdbcTools.getConnection();
preparedStatement = connection.prepareStatement(sql); for(i=0;i<args.length;i++){
preparedStatement.setObject(i+1,args[i]);
}
resultSet = preparedStatement.executeQuery(); //2、获取数据集元数据,即ResultSetMetaData对象
ResultSetMetaData rsmd = resultSet.getMetaData(); //3和4,获取列名和值,创建map对象
Map<String,Object> values = new HashMap<String,Object>(); while(resultSet.next()){
for(int i = 0;i<rsmd.getColumnCount();i++){ String columnLabel = rsmd.getColumnLabel(i+1);
Object columnValue = resultSet.getObject(columnLabel);
values.put(columnLabel,columnValue); }
} //5、创建实例,并通过反射赋值
entity = clazz.newInstance(); for(Map.Entry<String,Object> entry: values.entrySet()){
String fieldName = entry.getKey();
Object fieldValue = entry.getValue();
///反射工具类需要自己实现
//ReflectUtils.setFieldValue(entity,fieldName,fieldValue);
          BeanUtils.setProperty(entity,fieldname,fieldValue);
} }catch (Exception e){
e.printStackTrace(); }finally {
jdbcTools.releaseResource(resultSet,preparedStatement,connection);
}
return entity;
}

上面的方法是返回一个对象,如果需要返回多条记录,则需要重新写一个方法

  public <T> List<T> getForList(Class<T> clazz, String sql, Object...args) throws Exception{
List<T> list = null;
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null; try{
connection = jdbcTools.getConnection();
preparedStatement = connection.prepareStatement(sql);
for(int i = 0;i<args.length;i++){
preparedStatement.setObject(i+1,args[i]);
} resultSet = preparedStatement.executeQuery();
ResultSetMetaData rsmd = resultSet.getMetaData();
List<Map<String,Object>> values = new ArrayList<Map<String, Object>>(); Map<String,Object> map = null; while(resultSet.next()){
map = new HashMap<String, Object>();
for(int i = 0;i< rsmd.getColumnCount();i++){
String fieldName = rsmd.getColumnLabel(i+1);
Object object = resultSet.getObject(i+1);
map.put(fieldName,object);
}
values.add(map);
} T bean = null;
if(values != null ){
for(Map<String,Object> m: values){
for(Map.Entry<String,Object> entry : m.entrySet()) {
String fieldName = entry.getKey();
Object fieldValue = entry.getValue();
bean = clazz.newInstance();
BeanUtils.setProperty(bean,fieldName,fieldValue); }
list.add(bean);
}
} }catch (Exception e){
e.printStackTrace();
}finally {
jdbcTools.releaseResource(resultSet,preparedStatement,connection);
} return list; }

利用反射及JDBC元数据编写通用查询方法的更多相关文章

  1. Java -- JDBC_利用反射及 JDBC 元数据编写通用的查询方法

    先利用 SQL 进行查询,得到结果集: 利用反射创建实体类的对象:创建对象: 获取结果集的列的别名: 再获取结果集的每一列的值, 结合 3 得到一个 Map,键:列的别名,值:列的值: 再利用反射为 ...

  2. JDBC学习笔记(5)——利用反射及JDBC元数据编写通用的查询方法

    JDBC元数据 1)DatabaseMetaData /** * 了解即可:DatabaseMetaData是描述数据库的元数据对象 * 可以由Connection得到 */ 具体的应用代码: @Te ...

  3. 【转】JDBC学习笔记(5)——利用反射及JDBC元数据编写通用的查询方法

    转自:http://www.cnblogs.com/ysw-go/ JDBC元数据 1)DatabaseMetaData /** * 了解即可:DatabaseMetaData是描述数据库的元数据对象 ...

  4. <五>JDBC_利用反射及JDBC元数据编写通用的查询方法

    此类针对javaBean类写了一个通用的查询方法,List<javaBean> 通用查询更新中...:通过学习,深刻体会到学会反射就等于掌握了java基础的半壁江山! 一.使用JDBC驱动 ...

  5. MYSQL 之 JDBC(六): 增删改查(四)利用反射及JDBC元数据编写通用的查询

    1.先利用SQL进行查询,得到结果集2.利用反射创建实体类的对象:创建Student对象3.获取结果集的列的别名:idCard.studentName4.再获取结果集的每一列的值,结合3得到一个Map ...

  6. 利用反射及jdbc元数据实现通用的查询方法

    ---------------------------------------------------------------------------------------------------- ...

  7. 利用反射和JDBC元数据实现更加通用的查询方法

    package com.at221.jdbc; import java.io.IOException; import java.io.InputStream; import java.sql.*; i ...

  8. JDBC--利用反射及JDBC元数据编写通用的查询方法

    1.JDBC元数据(ResuleSetMetaData):描述ResultSet的元数据对象,可以从中获取到结果集中的列数和列名等: --使用ResultSet类的getMetaData()方法获得R ...

  9. java攻城狮之路--复习JDBC(利用BeanUtils、JDBC元数据编写通用的查询方法;元数据;Blob;事务;批量处理)

    1.利用BeanUtils的前提得要加入以下两个jar包: commons-beanutils-1.8.0.jar commons-logging-1.1.1.jar package com.shel ...

随机推荐

  1. 在Eclipse上建立hbase 0.98.3/0.96.2源代码阅读环境

    2.1. 切换到源代码目录,执行: mvn 黄色部分作用为设置代理.由于本人的编译环境在公司内网,所以需要设置代理 2.2. 生成eclipse项目环境: mvn eclipse:eclipse -D ...

  2. ubuntu 13.04 tftp服务器建立

    本文参考博文:http://blog.chinaunix.net/uid-20718037-id-3194493.html 用tftp下载就需要要我们的主机上先安装tftp服务器.    1.安装软件 ...

  3. CSS强制中英文换行与不换行

    1. word-break:break-all; 只对英文起作用,以字母作为换行依据 2. word-wrap:break-word; 只对英文起作用,以单词作为换行依据 3. white-space ...

  4. 1、Android Bitmap详细介绍

    import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io ...

  5. Android 字体相关总结

    1.Android系统默认支持三种字体,分别为:“sans”, “serif”,  “monospace“  系统缺省方式(经试验缺省采用采用sans): 2.在Android中可以引入其他字体 3. ...

  6. Azure媒体服务的Apple FairPlay流功能正式上线

    在此我们高兴地宣布,Azure FairPlay Streaming服务已正式商用. FairPlay允许用户轻松构建解决方案,并可扩展到最新版本的Apple TV.Azure媒体服务可以结合现有的P ...

  7. 腾讯优测-优社区干货精选 |  那些年,我们在Android机型适配上遇到的坑之Camera拍照时快门咔嚓声

    文/腾讯优测研发工程师 吴宇焕 优测小优有话说: android机型适配的坑自然是不少,不想掉坑快来优测优社区~ 现在Android手机一般都会带有照相功能,有很多朋友就发现手机照相时快门声音很响,想 ...

  8. id 和 instancetype

    静态数据类型 默认情况下所有的数据类型都是静态数据类型 静态数据类型的特点: 1 在编译时就知道变量的类型 2 知道变量中有哪些属性和方法 3 在编译的时候就可以访问这些属性和方法 4 并且如果是通过 ...

  9. springMVC返回json

    <mvc:annotation-driven> <mvc:message-converters register-defaults="true"> < ...

  10. 大道至简---软件工程实践者的思想------------java伪代码形式读后感第一章

    import.java.大道至简.*; 1.编程的精义----愚公移山 /* 原始需求的产生:惩山北之塞,出入之迂 项目沟通的基本方式:聚室而谋曰 项目的目标:毕力平险,指通豫南,达于汉阴 技术方案: ...