sql查询化繁为简 告别rs.getString("XX"),bean属性赋值setXX("XX")
一、在执行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")的更多相关文章
- 【小家Spring】Spring IoC是如何使用BeanWrapper和Java内省结合起来给Bean属性赋值的
#### 每篇一句 > 具备了技术深度,遇到问题可以快速定位并从根本上解决.有了技术深度之后,学习其它技术可以更快,再深入其它技术也就不会害怕 #### 相关阅读 [[小家Spring]聊聊Sp ...
- 依赖注入Bean属性
一.Bean属性依赖注入 对于类成员变量,注入方式有三种 •构造函数注入 •属性setter方法注入 •接口注入 Spring支持前两种 1.构造函数 属性注入 使用构造方法注入,在Spring配置文 ...
- 笔面试复习(spring常用.jar包/事务/控制反转/bean对象管理和创建/springMVC工作原理/sql查询)
###spring常用jar包1.spring.jar是包含有完整发布模块的单个jar包.2.org.springframework.aop包含在应用中使用Spring的AOP特性时所需要的类.3.o ...
- Java 获取SQL查询语句结果
step1:构造连接Class.forName("com.mysql.jdbc.Driver"); Connection con = DriverManager.getConnec ...
- 使用sql查询mysql/oracle/sql server/gp数据库中指定表的字段信息(字段名/字段类型/字段长度/是否是主键/是否为空)
1,根据数据库类型拼接不同URL /** * 根据类型不同拼接连接的URL * @param dbType 1:mysql.2:oracle.3:sql server.4:gp * @param ip ...
- SQL查询语句大全集锦
SQL查询语句大全集锦 一. 简单查询 简单的Transact-SQL查询只包括选择列表.FROM子句和WHERE子句.它们分别说明所查询列.查询的 表或视图.以及搜索条件等. 例如,下面的语句查询t ...
- Java连接MySQL数据库实现用户名密码的验证方法 Java语句中sql查询语句'' ""作用
//方法一,可以验证登录,但方法不实用.package com.swift; import java.sql.Connection; import java.sql.DriverManager; im ...
- SolrCloud6.1.0之SQL查询测试
Solr发展飞快,现在最新的版本已经6.1.0了,下面来回顾下Solr6.x之后的一些新的特点: (1)并行SQL特性支持,编译成Streaming 表达式,可以在solrcloud集群中,并行执行 ...
- JDBC 处理sql查询多个不确定参数
JDBC程序,为了防止SQL注入,通常需要进行参数化查询,但是如果存在多个不确定参数,就比较麻烦了,查阅了一些资料,最后解决了这个问题,现在这里记录一下: public List<TabDl ...
随机推荐
- C++课程设计2
PS:大一下学期C++课程设计 1.成绩管理系统 #include<stdio.h> #include<string> #include<iostream> #in ...
- CCF-201312-4-有趣的数
问题描述 试题编号: 201312-4 试题名称: 有趣的数 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 我们把一个数称为有趣的,当且仅当: 1. 它的数字只包含0, 1, ...
- 完成你的第一个superMap示例
1.从官网下载superMap安装包,我选择setup包 2.解压压缩文件后,按照readme指导书,运行setup.exe进行安装 解压后压缩包包含文件: 执行setup.exe进行安装,其中Sup ...
- kubernetes入门实践
k8s中文文档 k8s概念比较多,有什么概念的疑惑的推荐看k8s中文文档. me的环境 操作系统:centos7 docker:1.12.6 环境跟me的不一致?不要慌,基本大部分操作都是行的通的. ...
- 在centos7中手动编译greenplum
一.编译环境 Linux version 3.10.0-327.el7.x86_64 (builder@kbuilder.dev.centos.org) (gcc version 4.8.3 2014 ...
- JAVA入门[18]-JdbcTemplate简单实例
一.关于JdbcTemplate JdbcTemplate是最基本的Spring JDBC模板,这个模板支持简单的JDBC数据库访问功能以及基于索引参数的查询. Spring数据访问模板:在数据库操作 ...
- 三.RabbitMQ之异步消息队列(Work Queue)
上一篇文章简要介绍了RabbitMQ的基本知识点,并且写了一个简单的发送和接收消息的demo.这一篇文章继续介绍关于Work Queue(工作队列)方面的知识点,用于实现多个工作进程的分发式任务. 一 ...
- 配置nginx以获取真实的客户端ip地址
当我们使用了nginx来转发客户端的请求以后,tomcat是无法正确获取到客户端的ip地址的,而是获取到配置了nginx的那台服务器的ip地址.因为tomcat所接收到的请求是通过nginx发出来的( ...
- 《C++程序设计语言(十周年纪念版)》【PDF】下载
<C++程序设计语言(十周年纪念版)>[PDF]下载链接: https://u253469.pipipan.com/fs/253469-230382171 内容简介 <C++程序设计 ...
- ligerUI---下拉框(Combobox)
写在前面: 突然发现,从刚开始对ligerUI的抵触,觉得都没有接触过,也不会,到现在,感觉ligerUI的一些组件还是挺好用的,大概日久生情吧.嘻嘻~~~,下拉框是常用的一个组件,在之前的博客中也写 ...