java 利用反射 从数据库取出数据对象list 类似hibernate

2024-05-13 20:08

本文主要是介绍java 利用反射 从数据库取出数据对象list 类似hibernate,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这两天在写框架,觉得这个很实用,贴上来共享!

主要作用就是 根据返回的结果集,然后读取对象的字段,调用set方法,把对应的值放入对象。

用过hibernate的人应该知道,实现的功能是一样的。

代码:

CollectionsHelper .java

package org.pan.sql;import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import org.pan.convetor.FieldConvertor;
import org.pan.util.MethodsUitl;
import org.pan.util.StringUitl;/*** 集合助手,查询数据库返回对象列表* @author Pan**/
public class CollectionsHelper {private List<Object> list=new ArrayList<Object>();public  CollectionsHelper(Object object ,ResultSet rs){try{String [] colunms=ColumnHelper.getColumn(rs);while (rs.next()) {//创建新的对象并实例化Object ob=Class.forName(object.getClass().getName()).newInstance();Method [] methods=ob.getClass().getMethods();for(int i=0;i<colunms.length;i++){String value = rs.getString(colunms[i]).trim();String label=colunms[i];if(MethodsUitl.exist(methods,"set"+label)){if(label!=null){Field field=ob.getClass().getDeclaredField(StringUitl.lowercase(label));if(field!=null){FieldConvertor.convertor(ob, field,value);}}}}list.add(ob);}}catch (Exception e) {	System.err.println(e);}}public List<Object> getList() {return list;}
}

除了上面代码之外,还需要一个类,那就是类型转换器,如果没有进行类型转换,会抛错。

类型转换器:

package org.pan.convetor;import java.lang.reflect.Field;
import java.sql.Timestamp;import org.pan.exception.FieldConversionException;/*** 类型转换器* @author Pan* */
public class FieldConvertor {public static void convertor(Object object, Field field, String value)throws FieldConversionException {//设置字段可访问 否则会报错field.setAccessible(true);String type = field.getType().getName();try {if (type.equals("java.lang.String")) {field.set(object, value.toString());} else if (type.equals("java.lang.Integer")) {field.set(object, Integer.parseInt(value));} else if (type.equals("int")) {field.set(object, Integer.parseInt(value));} else if (type.equals("java.lang.Double")) {field.set(object, Double.parseDouble(value));} else if (type.equals("double")) {field.set(object, Double.parseDouble(value));} else if (type.equals("java.lang.Float")) {field.set(object, Float.parseFloat(value));} else if (type.equals("float")) {field.set(object, Float.parseFloat(value));} else if (type.equals("java.lang.Boolean")) {field.set(object, Boolean.parseBoolean(value));} else if (type.equals("boolean")) {field.set(object, Boolean.parseBoolean(value));} else if (type.equals("java.lang.Long")) {field.set(object, Long.parseLong(value));} else if (type.equals("boolean")) {field.set(object, Long.parseLong(value));} else if (type.equals("char")|| type.equals("java.lang.Character")) {field.set(object, value.charAt(0));} else if (type.equals("java.lang.Short") || type.equals("short")) {field.set(object, Short.parseShort(value));}else if(type.equals("java.sql.Timestamp")){field.set(object, Timestamp.valueOf(value));}} catch (Exception e) {
//			throw new FieldConversionException(
//					"Field type conversion exception ! Field:"
//							+ field.getName());System.err.println(e);}}
}

注:转载请注明来源。2013年5月23日 22:09:12

这篇关于java 利用反射 从数据库取出数据对象list 类似hibernate的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/986695

相关文章

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

IDEA如何切换数据库版本mysql5或mysql8

《IDEA如何切换数据库版本mysql5或mysql8》本文介绍了如何将IntelliJIDEA从MySQL5切换到MySQL8的详细步骤,包括下载MySQL8、安装、配置、停止旧服务、启动新服务以及... 目录问题描述解决方案第一步第二步第三步第四步第五步总结问题描述最近想开发一个新应用,想使用mysq

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

Spring MVC如何设置响应

《SpringMVC如何设置响应》本文介绍了如何在Spring框架中设置响应,并通过不同的注解返回静态页面、HTML片段和JSON数据,此外,还讲解了如何设置响应的状态码和Header... 目录1. 返回静态页面1.1 Spring 默认扫描路径1.2 @RestController2. 返回 html2

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去