一、在执行sql语句查询时候,查询的结果是set的map集合(ResultSet);

  结果使用rs.getString("XX")获得对应属性的值,赋值到bean对象的相应的属性中,使用bean.setXX(rs.getString("XX"))

  弊端:1、当bean对象的属性众多,写法非常麻烦,浪费人力,容易出错;

     2、后期代码修改,耦合性太高,一个属性修改,sql使用到的setget都要修改;

     3、java是面向对象编程的,此处没有抽取方法,代码复用性低;

   String sql = "SELECT * FROM olt_basic where synchronousstatus = 'SU' and tachniquestatus = 'WA' or (tachniquestatus = 'FA' and tachniquecount < 3)";
                         ResultSet rs = DataBaseOperate.executQuery(sql);
                         list = new ArrayList();
                         int firstNum = 1;
                         while (rs.next()) {
                             Basic basic = new Basic();
                             String basicId = rs.getString("Olt_Basic_ID");
                             String batchCode = rs.getString("BATCHCODE");
                             String batchName = rs.getString("BATCHNAME");
                             String sectionCode = rs.getString("SECTIONCODE");
                             String sectionName = rs.getString("SECTIONNAME");
                             String packageId = rs.getString("PACKAGEID");
                             String packageName = rs.getString("PACKAGENAME");
                             String packageCode = rs.getString("PACKAGECODE");
                             String packageValue = rs.getString("PACKAGEVALUE");
                             String bidderCode = rs.getString("BIDDERCODE");
                             String tachniquecount = rs.getString("Tachniquecount");
                             basic.setOlt_basic_id(basicId);
                             basic.setBatchcode(batchCode);
                             basic.setBatchname(batchName);
                             basic.setSectioncode(sectionCode);
                             basic.setSectionname(sectionName);
                             basic.setPackageid(packageId);
                             basic.setPackagename(packageName);
                             basic.setPackagecode(packageCode);
                             basic.setPackagevalue(packageValue);
                             basic.setBiddercode(bidderCode);
                             basic.setTachniquecount(tachniquecount);
                             list.add(basic);
                             firstNum++;
                         }

二、sql查询化繁为简

  使用commons-beanutils-1.9.3.jar架包,Set的map集合赋值到bean的属性值中;

  1、bean的对象的属性名称与数据库的字段名称对应

  2、reslut的结果转成map,使用BeanUtils.populate(对象,map)方法,将map中的值赋值到bean中对应的属性中

 List<OltBasic> listResult = new ArrayList<OltBasic>(100);
             StringBuffer sql = new StringBuffer();
             sql.append(" select * from olt_basic ob ");
             prepared = connection.prepareStatement(sql.toString());
             ResultSet resultSet = prepared.executeQuery();
             while (resultSet.next())
             {
                 Map<String, String> map = ResultToMapUtil.resultToMap(resultSet);
                 OltBasic bean = new OltBasic();
                 BeanUtils.populate(bean,map);
                 listResult.add(bean);
             }  

  

sql查询化繁为简 告别rs.getString("XX"),bean属性赋值setXX("XX")的更多相关文章

  1. 【小家Spring】Spring IoC是如何使用BeanWrapper和Java内省结合起来给Bean属性赋值的

    #### 每篇一句 > 具备了技术深度,遇到问题可以快速定位并从根本上解决.有了技术深度之后,学习其它技术可以更快,再深入其它技术也就不会害怕 #### 相关阅读 [[小家Spring]聊聊Sp ...

  2. 依赖注入Bean属性

    一.Bean属性依赖注入 对于类成员变量,注入方式有三种 •构造函数注入 •属性setter方法注入 •接口注入 Spring支持前两种 1.构造函数 属性注入 使用构造方法注入,在Spring配置文 ...

  3. 笔面试复习(spring常用.jar包/事务/控制反转/bean对象管理和创建/springMVC工作原理/sql查询)

    ###spring常用jar包1.spring.jar是包含有完整发布模块的单个jar包.2.org.springframework.aop包含在应用中使用Spring的AOP特性时所需要的类.3.o ...

  4. Java 获取SQL查询语句结果

    step1:构造连接Class.forName("com.mysql.jdbc.Driver"); Connection con = DriverManager.getConnec ...

  5. 使用sql查询mysql/oracle/sql server/gp数据库中指定表的字段信息(字段名/字段类型/字段长度/是否是主键/是否为空)

    1,根据数据库类型拼接不同URL /** * 根据类型不同拼接连接的URL * @param dbType 1:mysql.2:oracle.3:sql server.4:gp * @param ip ...

  6. SQL查询语句大全集锦

    SQL查询语句大全集锦 一. 简单查询 简单的Transact-SQL查询只包括选择列表.FROM子句和WHERE子句.它们分别说明所查询列.查询的 表或视图.以及搜索条件等. 例如,下面的语句查询t ...

  7. Java连接MySQL数据库实现用户名密码的验证方法 Java语句中sql查询语句'' ""作用

    //方法一,可以验证登录,但方法不实用.package com.swift; import java.sql.Connection; import java.sql.DriverManager; im ...

  8. SolrCloud6.1.0之SQL查询测试

    Solr发展飞快,现在最新的版本已经6.1.0了,下面来回顾下Solr6.x之后的一些新的特点: (1)并行SQL特性支持,编译成Streaming 表达式,可以在solrcloud集群中,并行执行  ...

  9. JDBC 处理sql查询多个不确定参数

    JDBC程序,为了防止SQL注入,通常需要进行参数化查询,但是如果存在多个不确定参数,就比较麻烦了,查阅了一些资料,最后解决了这个问题,现在这里记录一下:   public List<TabDl ...

随机推荐

  1. PAT 1008. Elevator (20)

    1008. Elevator (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue The highest ...

  2. gis电子地图开发公司面临的挑战和机遇

    从上个世纪90年代开始电子地图应用就已经收到人们的关注,但是由于时代的局限性和市场经济发展的不成熟.地理信息系统系统的应用并没有得到很好的利用.只有少数的国家机构和军事系统才能够使用这些应用.随着技术 ...

  3. zuul超时的解决方案

    参考http://www.coolxuewang.com/view/10 在zuul的配置文件里增加如下配置: ribbon:    ConnectTimeout: 6000    ReadTimeo ...

  4. JaveScript简单数据类型(JS知识点归纳二)

    JS中的简单数据类型有五种 : --> string --> number -->boolean --> null -->undefined 数据类型的检测 :typeo ...

  5. MySQL远程訪问的两个问题

    安装MySQL后,不能远程訪问.进行例如以下配置就可以 连接后,依旧不能连接,报例如以下错误: 1042 - Can't get hostname for your address 解决方法在my.i ...

  6. 003Java语言环境搭建

    JRE,JDK JRE(Java Runtime Environment java运行环境):包括java虚拟机和java程序所需要的核心类库, 如果要运行一个开发好的java程序,计算机中只需要安装 ...

  7. 基于FPGA的图像显示

    基于FPGA的图像显示 作者:lee神 这几天一直在调试FPGA的图像显示系统,今天终于成功,图像不在闪烁,也不再边框缺失. 基于FPGA的图像处理的第一课应该是基于FPGA的图像显示,只有图像正常显 ...

  8. 大白话Vue源码系列(04):生成render函数

    阅读目录 优化 AST 生成 render 函数 小结 本来以为 Vue 的编译器模块比较好欺负,结果发现并没有那么简单.每一种语法指令都要考虑到,处理起来相当复杂.上篇已经生成了 AST,本篇依然对 ...

  9. jmeter的使用---web测试

    jmeter的使用---web测试 url:http://127.0.0.1:1080/WebTours/ 1.通过badboy录制脚本 1.1输入url点击右侧的跳转按钮,随后右侧显示url界面 1 ...

  10. Winform开发框架中工作流模块之申请单草稿处理

    在我们开发工作流模块的时候,有时候填写申请单过程中,暂时不想提交审批,那么可以暂存为草稿,以供下次继续填写或者提交处理,那么这个草稿的功能是比较实用的,否则对于一些填写内容比较多的申请单,每次要重填写 ...