我是靠谱客的博主 无语发卡,最近开发中收集的这篇文章主要介绍jdbc 通过反射和元数据编写通用的查询对象方法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

/**
 * 通过反射和泛型编写通用的查询
 * @param clazz
 * @param sql
 * @param objects
 * @return
 * @throws Exception
 */
public <T> T getObject(Class<T> clazz,String sql,Object ...objects) throws Exception{
T entity = null;
Connection connection = C3p0Utils.newInstance().getConnection();
PreparedStatement preparedStatement = connection.prepareStatement(sql);
for(int i=0;i<objects.length;i++){
preparedStatement.setObject(i+1, objects[i]);
}
ResultSet resultSet = preparedStatement.executeQuery();
ResultSetMetaData resultSetMetaData = resultSet.getMetaData();
int columnCount = resultSetMetaData.getColumnCount();
Map<String,Object> map = new HashMap<String,Object>();
if(resultSet.next()){
for(int i=0;i<columnCount;i++){
String fieldName = resultSetMetaData.getColumnLabel(i+1);
Object fieldValue = resultSet.getObject(i+1);
map.put(fieldName, fieldValue);
}
}
System.out.println("map:"+map);
entity = clazz.newInstance();
for(Map.Entry<String, Object> entry : map.entrySet()){
String name = entry.getKey();
Object value = entry.getValue();
Method method = clazz.getMethod(toMethod(name), toClass(clazz, name));
method.invoke(entity, value);
}
return entity;
}
/**
 * 将字段名转换为方法名
 * @param name
 * @return
 */
public String toMethod(String name){
    return "set"+name.substring(0, 1).toUpperCase()+name.substring(1);
}
/**
 * 获取指定字段的数据类型
 * @param clazz
 * @param name
 * @return
 * @throws Exception
 */
 public Class toClass(Class clazz,String name) throws Exception{
	Field field = clazz.getDeclaredField(name);
	return field.getType();
  }


转载于:https://blog.51cto.com/11147669/1905603

最后

以上就是无语发卡为你收集整理的jdbc 通过反射和元数据编写通用的查询对象方法的全部内容,希望文章能够帮你解决jdbc 通过反射和元数据编写通用的查询对象方法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(46)

评论列表共有 0 条评论

立即
投稿
返回
顶部