在做web开发时遇到一个事情:

需要从mysql数据表中查询数据并遍历查询结果

这样最简单的方式是:查询到结果根据表中字段列表的顺序来一个个获取字段,但这样需要记住字段的顺序,操作起来不是那么方便。因此便想可不可以把查询结果

ResultSet转化成java的实例对象,然后利用类对象的get方法,这样会方便清晰很多。

查了下,有很多可以参考,于是参考着有了自己的代码,如下:

1.mapper函数:

package com.alibaba.search.offline.oddiff.service;

import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import javax.persistence.Column;
import javax.persistence.Entity;
import org.apache.commons.beanutils.BeanUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import com.jcraft.jsch.Logger;

//import com.alibaba.druid.sql.ast.statement.SQLCreateViewStatement.Column;

public class OddiffResultSetMapper<T> {
protected static Log logger = LogFactory.getLog(OddiffResultSetMapper.class);
@SuppressWarnings("unchecked")
public List<T> mapRersultSetToObject(ResultSet rs, Class outputClass) {
List<T> outputList = null;
try {
// make sure resultset is not null
if (rs != null) {
logger.info("rs:"+rs);
// check if outputClass has 'Entity' annotation
if (outputClass.isAnnotationPresent(Entity.class)) {
// get the resultset metadata
ResultSetMetaData rsmd = rs.getMetaData();
// get all the attributes of outputClass
Field[] fields = outputClass.getDeclaredFields();
while (rs.next()) {
T bean = (T) outputClass.newInstance();
for (int _iterator = 0; _iterator < rsmd.getColumnCount(); _iterator++) {
// getting the SQL column name
String columnName = rsmd.getColumnName(_iterator + 1);

// reading the value of the SQL column
Object columnValue = rs.getObject(_iterator + 1);
logger.info("columnName:"+columnName+",value:"+columnValue);
for (Field field : fields) {
if (field.isAnnotationPresent(Column.class)) {
Column column = field.getAnnotation(Column.class);
if (column.name().equalsIgnoreCase(columnName) && columnValue != null) {
BeanUtils.setProperty(bean, field.getName(), columnValue);
break;
}
}
}
}
if (outputList == null) {
outputList = new ArrayList<T>();
}
outputList.add(bean);
}

} else {
// throw some error
}
} else {
logger.info("rs is null");
return null;
}
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
return outputList;
}
}

2.类对象的声明:

package com.alibaba.search.offline.oddiff.service;

import java.util.Date;

import javax.persistence.Column;

import javax.persistence.Entity;

@Entity

public class OddiffEntity {

@Column(name="id")

private Integer Id;

@Column(name="user_name")

private String userName;

@Column(name="app_name")

private String appName;

@Column(name="online_version")

private String onlineVersion;

@Column(name="oa_version")

private String oaVersion;

@Column(name="data_name")

private String dataName;

@Column(name="start_time")

private String startTime;

@Column(name="end_time")

private String endTime;

@Column(name="commit_time")

private String commitTime;

@Column(name="duration_time")

private String durationTime;

@Column(name="status")

private String status;

@Column(name="log_file")

private String logFile;

public void setId(Integer id) {

this.Id = id;

}

public Integer getId() {

return Id;

}

public void setUserName(String userName) {

this.userName = userName;

}

public String getUserName() {

return userName;

}

public void setAppName(String appName) {

this.appName = appName;

}

public String getAppName() {

return appName;

}

public void setOnlineVersion(String onlineVersion) {

this.onlineVersion = onlineVersion;

}

public String getOnlineVersion() {

return onlineVersion;

}

public void setOaVersion(String oaVersion) {

this.oaVersion = oaVersion;

}

public String getOaVersion() {

return this.oaVersion;

}

public void setDataName(String dataName) {

this.dataName = dataName;

}

public String getDataName() {

return dataName;

}

public void setStartTime(String startTime) {

this.startTime = startTime;

}

public String getStartTime() {

return startTime;

}

public void setEndTime(String endTime) {

this.endTime = endTime;

}

public String getEndTime() {

return endTime;

}

public void setCommitTime(String commitTime) {

this.commitTime = commitTime;

}

public String getCommitTime() {

return commitTime;

}

public void setDurationTime(String durationTime) {

this.durationTime = durationTime;

}

public String getDurationTime() {

return durationTime;

}

public void setStatus(String status) {

this.status = status;

}

public String getStatus() {

return status;

}

public void setLogFile(String logFile) {

this.logFile = logFile;

}

public String getLogFile() {

return logFile;

}

@Override

public String toString() {

return  "id: " + Id + "\n" +

"user_name: " + userName + "\n"+

"app_name: " + appName + "\n" ;

}

}

3.真的转化:

public static List<OddiffEntity> Execute_select(Connection conn, String sql) {

if (conn==null)

conn = getConn();//此处为通过自己写的方法getConn()获得连接

OddiffResultSetMapper<OddiffEntity> resultSetMapper = new OddiffResultSetMapper<OddiffEntity>();

try {

Statement stmt = conn.createStatement();

ResultSet rs = stmt.executeQuery(sql);

logger.info("---sql:"+sql);

logger.info("select result:"+rs.getFetchSize());

List<OddiffEntity> pojoList = resultSetMapper.mapRersultSetToObject(rs, OddiffEntity.class);

if (pojoList!=null){

for (OddiffEntity job:pojoList){

logger.info("job:"+job.toString());

}

}

return pojoList;

} catch (SQLException e) {

e.printStackTrace();

}

return null;

}

ResultSet转成java类对象的更多相关文章

  1. Mybaits 源码解析 (八)----- 全网最详细,没有之一:结果集 ResultSet 自动映射成实体类对象(上篇)

    上一篇文章我们已经将SQL发送到了数据库,并返回了ResultSet,接下来就是将结果集 ResultSet 自动映射成实体类对象.这样使用者就无需再手动操作结果集,并将数据填充到实体类对象中.这可大 ...

  2. 规则引擎集成接口(九)Java类对象

    Java类对象 右键点击“对象库” —“添加java类对象”,如下图: 弹出窗体,在文本框中输入类的全名“com.flagleader.test.Test”,选择该类型后确定,如下: 显示如下,勾选上 ...

  3. Gson把json串转换成java实体对象

    Gson把json串转换成java实体对象的方法如下: 1.首先导入Gson的jar包,网上可以下载. java实体对象如下: public class Model { private double ...

  4. 转: JaxbContext生成xml文件或java类对象转化注解

    JAXB(Java API for XML Binding),提供了一个快速便捷的方式将Java对象与XML进行转换.在JAX-WS(Java的WebService规范之一)中,JDK1.6 自带的版 ...

  5. 存在继承关系的Java类对象之间的类型转换(一)

      类似于基本数据类型之间的强制类型转换. 存在继承关系的父类对象和子类对象之间也可以 在一定条件之下相互转换. 这种转换需要遵守以下原则: 1.子类对象可以被视为是其父类的一个对象2.父类对象不能被 ...

  6. 将封装了envi功能的IDL类导出成java类,方便java调用

    目的:     用IDL将ENVI的功能封装成为IDL的类,并使用IDL的对象导出功能把这些功能类导出为java类,方便java调用.(本来想直接通过GP工具调用的,但是没有授权文件)   操作步骤: ...

  7. java类 对象 和构造方法

    github地址:https://github.com/lily1010/java_learn/tree/master/dog java中对象和类 java中万物皆对象,比如说动物,里面有猫,狗,鱼等 ...

  8. Java类对象数组声明和初始化

    Java是纯面向对象语言.类是其重要构成单位. 然后,在实际编程中,我们会自己定义一些类,如Point <span style="font-size:14px;">pu ...

  9. [转]java类 对象 和构造方法

    github地址:https://github.com/lily1010/java_learn/tree/master/dog java中对象和类 java中万物皆对象,比如说动物,里面有猫,狗,鱼等 ...

随机推荐

  1. 在英文 sql2005中 比较nvarchar 与 varchar的速度

    declare @str1 varchar(max); declare @count int; ; print 'begin' begin set @str1 = @str1 + '*'; ; end ...

  2. [Everyday Mathematics]20150106

    (1). 设 $f\in C[0,T]$, $g$ 是 $T$-周期函数, 试证: $$\bex \vlm{n}\int_0^T f(x)g(nx)\rd x=\frac{1}{T}\int_0^T ...

  3. Devexpress GridControl z

    http://minmin86121.blog.163.com/blog/static/4968115720144194923578/ 1 AllowNullInput=False; --Devexp ...

  4. [原创]谷歌插件 - YE搜图助手(YeImageFinder)

    最新版本:下载 版本:v1.5 更新时间:2014年10月08日  +完善了:YeImageFinder:支持在每次启用插件时,也能正常绑定右键! +完善了:每次做完动作后,就马上关闭自身! 版本:v ...

  5. 浏览器URL传参最大长度问题

    这几天为解决一个BUG头疼了一段时间,BUG现象如下: 一个选择人员的选择控件,当选择多个人时(50多个的时候),返回没有错误现象,而再一次打开的时候就报404错误.看到这个错误非常纳闷,无法下手,只 ...

  6. C++ 编程输入输出语句

    C++ 的标准输入.输出就是我们已经使用的包含头文件iostream,他不但提供了I/O的库函数,也提供了使用该库的流模式,从cin>> 流入  和cout<<流出到设备就是一 ...

  7. codeforce 702E Analysis of Pathes in Functional Graph RMQ+二进制

    http://codeforces.com/contest/702 题意:n个点,n条边,每个点出边只有一条,问从每个点出发经过k条边的边权和,以及边权最小值 思路: f[i][j] 第i个点出发,经 ...

  8. restsharp发送服务端请求回传session

    今天工作遇到这样一个场景,我需要获取一个游戏目录列表,这个列表接口在线上已经存在,但是这个接口需要登录认证后才能获取到,所以实现这个功能我打算分两部来做: 1.首先调登录接口,以写上session 2 ...

  9. Java每日一则-002

    Java中包的层级关系 java中的包在逻辑上是没有套嵌的,也就是说: java.lang 和 java.lang.awt 是两个平行的包,地位相等,互不相关.只不过一个名字叫java.lang另一个 ...

  10. JQuery好用的日期选择控件 DatePicker

    近期发现一个很好的基于JQ的前端UI日期选择控件Jquery.DatePicker.js 下载地址:jquery.DatePIcker.js 演示地址:DatePicker - 基于jQuery 1. ...