方法:

public static <T> List<T> processResultSetToList(ResultSet rs, Class<T> clazz) throws Exception {
List<T> ls = new ArrayList<T>();
Field[] fields = clazz.getDeclaredFields();
while (rs.next()) {
T tt = clazz.newInstance();
for (Field field : fields) {
try {
/**
* 如果Oracle数据库中的类型是 number p.getWriteMethod().invoke(tt, new
* Object[] { rs.getObject(p.getName()) }) 会报如下错误
* java.lang.IllegalArgumentException: argument type
* mismatch --- 另外如果mysql数据库中的bigint 在进行setXxxx(Integer
* val)时候也会抛出该异常 也会抛出该异常
*/
Object value = null;
try {
String fieldName = getColumnName(field);
switch (TypeUtils.getMappedType(field)) {
case Long:
value = Long.valueOf(rs.getLong(fieldName));
break;
case Integer:
value = Integer.valueOf(rs.getInt(fieldName));
break;
case Double:
value = Double.valueOf(rs.getDouble(fieldName));
break;
case Byte:
InputStream ins = rs.getBinaryStream(fieldName);
if(ins != null){
value = IOUtils.toByteArray(ins);
}
break;
case Date:
/**
* 15-12-8
* 转为util.Date
*/
Timestamp t = rs.getTimestamp(fieldName);
if(t!=null){
value = new Date(t.getTime());
}
break;
default:
value = rs.getObject(fieldName);
break;
}
} catch (Exception e) {// 如果仅仅查询Class的部分字段
if (e.getMessage().matches("Column\\s+'.+?'\\s+not\\s+found.")) {
switch (TypeUtils.getMappedType(field)) {
case Long:
case Integer:
value = 0;
break;
default:
value = null;
break;
}
}
}
field.setAccessible(true);
if(value != null){
field.set(tt, value);
}
} catch (IllegalArgumentException e) {
e.printStackTrace();
}
}
ls.add(tt);
}
DBUtils.close(rs, null, null);
return ls;
}

数据库对象映射为java对象,不使用框架的更多相关文章

  1. json字符串转json对象,json对象转换成java对象

    @RequestMapping(value = "updateInvestorApplyAccountNo", method = RequestMethod.POST) @Resp ...

  2. json字符串转成 json对象 json对象转换成java对象

    import com.alibaba.fastjson.JSONArray;import com.alibaba.fastjson.JSONObject; 依赖包 <dependency> ...

  3. JAVA反射机制示例,读取excel数据映射到JAVA对象中

    import java.beans.PropertyDescriptor; import java.io.File; import java.io.FileInputStream; import ja ...

  4. Java EE数据持久化框架 • 【第1章 MyBatis入门】

    全部章节   >>>> 本章目录 1.1 初识MyBatis 1.1.1 持久化技术介绍 1.1.2 MyBatis简介 1.1.2 Mybatis优点 1.1.3 利用Mav ...

  5. 【spring boot】映射properties文件属性--到Java对象

    描述 将*.properties中的内容映射到java对象中: 主要步骤 添加 @Component 注解: 使用 @PropertySource 注解指定配置文件位置: 使用 @Configurat ...

  6. java对象之----(PO,VO,DAO,BO,POJO)

    转自http://www.cnblogs.com/bluestorm/archive/2012/09/26/2703234.html 一.PO :(persistant object ),持久对象 可 ...

  7. java对象 Java中 VO、 PO、DO、DTO、 BO、 QO、DAO、POJO的概念

    PO(persistant object) 持久对象 在 o/r 映射的时候出现的概念,如果没有 o/r 映射,没有这个概念存在了.通常对应数据模型 ( 数据库 ), 本身还有部分业务逻辑的处理.可以 ...

  8. java对象与XML相互转化

    起因 最近在公司做了一次webservice相关的任务,其中我最敢兴趣的就是webservice接受到XML对应的流以后是如何方便的转化成java对象,而java对象又是如何生成对应的XML的. 目的 ...

  9. jackson java对象和json对象的互相转换

    概述 Jackson框架是基于Java平台的一套数据处理工具,被称为“最好的Java Json解析器”. Jackson框架包含了3个核心库:streaming,databind,annotation ...

随机推荐

  1. React,js实现分页的案列

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  2. 如何反编译DLL文件

    1.利用反编译器,多种工具,本次选用Reflector 8.5. 2.界面如下:

  3. tomcat域名访问配置

    模拟线上环境,在本地以域名访问系统思路 1.首先在hosts文件将域名映射为本地IP 2.假如服务器80端口已被占用,可以用nginx转发,在nginx/vhosts/abc.com加入如下配置 se ...

  4. linux服务器默认连接数配置

    vi /etc/security/limits.d/90-nproc.conf * - nofile 65536* - nproc 65536root soft nproc unlimited vi ...

  5. 【Java】代处理?代理模式 - 静态代理,动态代理

    >不用代理 有时候,我希望在一些方法前后都打印一些日志,于是有了如下代码. 这是一个处理float类型加法的方法,我想在调用它前打印一下参数,调用后打印下计算结果.(至于为什么不直接用+号运算, ...

  6. LabVIEW有限状态机

    顺序模式是我们最先接触,也是最基本的一种编程模式, 程序按照固定的顺序依次执行,结束(如图1) 但在很多情况下,静态的顺序模式并不能满足我们编程的要求,我们需要更有效地动态结构来实时改变程序的执行顺序 ...

  7. 什么是 Help Desk?

    科技如何帮助公司发展,关键就在于保证IT系统的安全稳定运行.我们都知道要保证系统100%可用非常难实现,那么如何在系统故障时减少处置时间?一个有效的办法就是帮助台(Help Desk).那么什么是帮助 ...

  8. springMVC简单示例

    1.新建web工程 2.引入springframework架包 3.配置文件 web.xml <?xml version="1.0" encoding="UTF-8 ...

  9. (转)内联(inline)函数与虚函数(virtual)的讨论

    本文转自: http://topic.csdn.net/t/20051220/09/4469273.html 函数的inline属性是在编译时确定的, 然而,virtual的性质是在运行时确定的,这两 ...

  10. python核心编程第六章练习6-9

    6-9.转换.为练习5-13写一个姊妹函数,接受分钟数,返回小时数和分钟数.总时间不变,并且要求小时尽可能大.[答案]代码如下: #!/usr/bin/env python # translate m ...