zoukankan      html  css  js  c++  java
  • Java工具类 通过ResultSet对象返回对应的实体List集合

    自从学了JDBC用多了像一下这种代码:

     
    ResultSet rs = this.executeQuery(sql, objs);
    List<xxx> list = new Array<xxx>();
    if(rs.next()){
    xxx x = new xxx();
    x.setxxx(rs.getString("xxx"));
    x.setsss(rs.getString("sss"));
    list.add(x);
    }

    这类相似的代码每天都在用,每天都在copy,相信大家早就已经烦了

    今天!Today!Java程序员的福利来了

    最近生病在家闲着无聊写了一个工具类:

      通过传入一个

      ResultSet对象和相应的实体类对象。可返回相应的List集合

      终于不用Ctrl+c  Ctrl+v了!!!!

    用到技术:

      Java反射机制

      泛型类

    实现思路:

      首先既然是工具类当然要做到 高可用,不然也没什么意义

      既然是通过一个ResultSet对象来返回一个实体集合,是个人都可以想到这个实体类一定是个不确定因素。

      ok , 想到 的是泛型类,定义一个虚拟类型T , 传参进来确切类型后然后通过反射来获得这个类的一系列信息

      然后进入赋值+list.add()操作

    我给这个工具类起名叫:DBRsHelp  (发现自己命名水准越来越高了  小小自恋一下下())

    废话不多说,上栗子(命名不规范,勿喷):

    package cn.news.util;
    
    import java.lang.reflect.Field;
    import java.sql.ResultSet;
    import java.util.ArrayList;
    import java.util.List;
    
    import cn.news.dao.BaseDAO;
    import cn.news.entity.Users;
    
    /**
     * 
     * @author: 房上的猫
     * 
     * @time: 下午3:49:32
     * 
     * @博客地址: https://www.cnblogs.com/lsy131479/
     *
     */

    //泛型类,T:虚拟类型
    public class DBRsHelp<T> { public List<T> util(T t, ResultSet rs) throws Exception { // 创建一个对应的空的泛型集合 List<T> list = new ArrayList<T>(); // 反射出类类型(方便后续做操作) Class c = t.getClass(); // 获得该类所有自己声明的字段,不问访问权限.所有。所有。所有 Field[] fs = c.getDeclaredFields(); // 大家熟悉的操作,不用多说 if (rs != null) { while (rs.next()) { // 创建实例 t = (T) c.newInstance(); // 赋值 for (int i = 0; i < fs.length; i++) { /* * fs[i].getName():获得字段名 * * f:获得的字段信息 */ Field f = t.getClass().getDeclaredField(fs[i].getName()); // 参数true 可跨越访问权限进行操作 f.setAccessible(true); /* * f.getType().getName():获得字段类型的名字 */ // 判断其类型进行赋值操作 if (f.getType().getName().equals(String.class.getName())) { f.set(t, rs.getString(fs[i].getName())); } else if (f.getType().getName().equals(int.class.getName())) { f.set(t, rs.getInt(fs[i].getName())); } } list.add(t); } } // 返回结果 return list; }   


      //测试一下下
    public static void main(String[] args) throws Exception { DBRsHelp<Users> util = new DBRsHelp<Users>(); Users u = new Users(); String sql = "select * from news_users"; BaseDAO dao = new BaseDAO(); dao.rs = dao.executeQuery(sql); List<Users> util1 = util.util(u, dao.rs); for (Users users : util1) { System.out.println("uname:" + users.getUname()); System.out.println("upwd:" + users.getUpwd()); System.out.println("ustart:" + users.getUstate()); System.out.println("usessionid:" + users.getUsessionid()); System.out.println("================================================"); } } }

    成功!!!哈哈哈

    写这个工具类还弄出一个笑话,跟大家分享一下:

    因为生病的原因一开始写的时候 t.getClass(); 硬生生写成了 toString().getClass()

    运行后控制台一直包这个错:

    心里一直想着:是啊老子是没这个字段啊,而且实体类也没啊,,,纠结了一天没出结果,晚上睡了一觉,第二天早上起来拿出来代码一看

    卧槽,我他妈真煞笔。。。

    (C) 房上的猫 。 保留所有权利。
     https://www.cnblogs.com/lsy131479/

    如需转载,请注明出处!!!

  • 相关阅读:
    HDU1548图论Dijkstra
    LINUX下sql常用命令
    Oracle DBLINK 简单使用
    自己常用百度搜索指令
    Element获取table中选中的行
    【Java】SpringBoot不扫描某个包
    Oracle创建Database link方法
    Oracle数据库中快照的使用
    spring.profiles.active和spring.profiles.include的使用与区别
    Spring Cloud Config 实现配置中心,看这一篇就够了
  • 原文地址:https://www.cnblogs.com/lsy131479/p/9037786.html
Copyright © 2011-2022 走看看