package com.ydbg.gis.utils;

import java.sql.SQLException;
import java.util.List;
import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ColumnListHandler;
import org.apache.commons.dbutils.handlers.MapHandler;
import org.apache.commons.dbutils.handlers.MapListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import org.apache.commons.lang.NumberUtils; /**
* @author y
* @date 2015-5-10 10:43:04
* @version V1.0
* @desc QuerryRunner 工具类
*/
public final class QrUtil { private static final QueryRunner qr = new QueryRunner(); private static class QrUtilHolder{
private static final QrUtil instance = new QrUtil();
} public static QrUtil getInstance(){
return QrUtilHolder.instance;
} /**
* 执行 insert,delete,update
* @param sql
* @param params
* @return
*/
public int update(String sql, Object params[]) {
int i = -1; try {
i = qr.update(TransactionManager.getInstance().get(), sql, params);
} catch (SQLException ex) {
Logger.getLogger(QrUtil.class.getName()).log(Level.SEVERE, null, ex);
} finally{
TransactionManager.getInstance().close();
} return i;
} /**
* 执行多条的 insert,update
* @param sql
* @param params
* @return
*/
public int batch(String sql, Object params[][]) {
int i = -1; try {
i = qr.batch(TransactionManager.getInstance().get(), sql, params).length;
} catch (SQLException ex) {
Logger.getLogger(QrUtil.class.getName()).log(Level.SEVERE, null, ex);
} finally{
TransactionManager.getInstance().close();
} return i;
} /**
* 查询一个实体Bean,返回结果要进行强制类型转换
* @param sql
* @param params
* @param clazz
* @return
*/
public Object queryBean(String sql, Object params[], Class clazz) {
Object obj = null; try {
obj = qr.query(TransactionManager.getInstance().get(), sql, new BeanHandler(clazz), params);
} catch (SQLException ex) {
Logger.getLogger(QrUtil.class.getName()).log(Level.SEVERE, null, ex);
} finally{
TransactionManager.getInstance().close();
} return obj;
} /**
* 查询一个实体Bean Array,返回结果要进行强制类型转换
* @param sql
* @param params
* @param clazz
* @return
*/
public Object queryBeanList(String sql, Object params[], Class clazz) {
Object obj = null; try {
obj = qr.query(TransactionManager.getInstance().get(), sql, new BeanListHandler(clazz), params);
} catch (SQLException ex) {
Logger.getLogger(QrUtil.class.getName()).log(Level.SEVERE, null, ex);
} finally{
TransactionManager.getInstance().close();
} return obj;
} /**
* 获取一个Map
* @param sql
* @param params
* @return
*/
public Map<String, Object> queryMap(String sql, Object params[]) {
Map<String, Object> map = null; try {
map = qr.query(TransactionManager.getInstance().get(), sql, new MapHandler(), params);
} catch (SQLException ex) {
Logger.getLogger(QrUtil.class.getName()).log(Level.SEVERE, null, ex);
} finally{
TransactionManager.getInstance().close();
} return map;
} /**
* 获取List<Map<String,Object>>
* @param sql
* @param params
* @return
*/
public List<Map<String, Object>> queryListMap(String sql, Object params[]){
List<Map<String, Object>> list = null; try {
list = qr.query(TransactionManager.getInstance().get(), sql, new MapListHandler(), params);
} catch (SQLException ex) {
Logger.getLogger(QrUtil.class.getName()).log(Level.SEVERE, null, ex);
} finally{
TransactionManager.getInstance().close();
} return list;
} /**
* 进行查询操作,返回一个数值(一般用于select count(id) from table的处理)
* @param sql
* @param params
* @return
*/
public int queryForInt(String sql, Object params[]){
Object obj = null; try {
obj = qr.query(TransactionManager.getInstance().get(), sql, new ScalarHandler(), params);
} catch (SQLException ex) {
Logger.getLogger(QrUtil.class.getName()).log(Level.SEVERE, null, ex);
} finally{
TransactionManager.getInstance().close();
} return NumberUtils.stringToInt("" + obj, 0);
} /**
* 获取单列值
* @param sql
* @param params
* @return
*/
public List<String> queryListString(String sql, Object params[]) {
List<String> list = null; try {
list = qr.query(TransactionManager.getInstance().get(), sql, new ColumnListHandler<String>(1), params);
} catch (SQLException ex) {
Logger.getLogger(QrUtil.class.getName()).log(Level.SEVERE, null, ex);
} finally{
TransactionManager.getInstance().close();
} return list;
} }

使用方式:

public List<DjNsrxx> getDjNsrxxList(int count) {
sb.setLength(0);
sb.append(" select nsrdzdah,scjydz from gis_dj_nsrxx ")
.append(" where (lng is null or lat is null) and rownum<? "); Object params[] = {count}; return (List<DjNsrxx>) QrUtil.getInstance().queryBeanList(sb.toString(), params, DjNsrxx.class);
}

QuerryRunner Tools的更多相关文章

  1. 解决 Could not find com.android.tools.build:gradle 问题

    今天拉同事最新的代码,编译时老是报如下错误: Error:Could not find com.android.tools.build:gradle:2.2.0.Searched in the fol ...

  2. 免费的精品: Productivity Power Tools 动画演示

    Productivity Power Tools 是微软官方推出的 Visual Studio 扩展,被用以提高开发人员生产率.它的出现一定程度上弥补和完善了 Visual Studio 自身的不足, ...

  3. 2.Kali安装VMware tools(详细+异常处理)

    dnt@MT:~$ cd /media/cdrom0 进入光驱内 dnt@MT:/media/cdrom0$ ls 查看当前目录下有哪些内容manifest.txt run_upgrader.sh V ...

  4. 第三篇:Entity Framework CodeFirst & Model 映射 续篇 EntityFramework Power Tools 工具使用

    上一篇 第二篇:Entity Framework CodeFirst & Model 映射 主要介绍以Fluent API来实作EntityFramework CodeFirst,得到了大家一 ...

  5. Chrome Developer Tools:Timeline Panel说明

    一.Timeline panel 概况 Timeline工具栏可以详细检测出Web应用在加载过程中,时间花费情况的概览.这些应用包括下载资源,处理DOM事件, 页面布局渲染或者向屏幕绘制元素. 如下图 ...

  6. linux-虚拟机centos6.5安装tools

    1.在VMWare选VM -> Install VMWare Tools-,就会在桌面出现VMWare Tools图示让你安裝 2.进入CentOS桌面后,将光盘打开,看到了VMWareTool ...

  7. VMWare Tools 和 Shared folder(共享文件夹)

    转自: http://www.51testing.com/html/38/225738-143732.html 使用vmwar下shared folders功能实现vmware中host与ghost间 ...

  8. 用hibernate tools生成对应的sql应用代码

    参考资料: eclipse在线配置hibernate tools http://jingyan.baidu.com/article/db55b609959d154ba20a2f5d.html [图]H ...

  9. 解决Maven工程中报 Missing artifact jdk.tools:jdk.tools:

    jdk.tools:jdk.tools是与JDK一起分发的一个JAR文件,可以如下方式加入到Maven项目中:<dependency>    <groupId>jdk.tool ...

随机推荐

  1. [TCO 2012 Round 3A Level3] CowsMooing (数论,中国剩余定理,同余方程)

    题目:http://community.topcoder.com/stat?c=problem_statement&pm=12083 这道题还是挺耐想的(至少对我来说是这样).开始时我只会60 ...

  2. 关于 IOS Runtime Runloop 2

    Runtime 也就是运行时组件,一个纯C语言写的基础库. 我们平时编写的OC代码中, 程序运行过程时, 其实最终都是转成了runtime的C语言代码 Objective-C编写出来的程序必须得到ru ...

  3. HTTP学习笔记6-请求报头

    29,请求报头: 请求报头允许客户端向服务器端传递该请求的附加信息以及客户端自身的信息. 30,Accept: Accept请求报头域用于指定客户端接受哪类型的信息,例如:Accept: image/ ...

  4. 关于Android Canvas.drawText方法中的坐标参数的正确解释

    canvas.drawText("www.jcodecraeer.com", x, y, paint);  x和y参数是指定字符串中心的坐标吗?还是左上角的坐标?这个问题的直观印象 ...

  5. 简单使用NSURLConnection、NSURLRequest和NSURL

    以下是代码,凝视也写得比較清楚: 头文件须要实现协议NSURLConnectionDelegate和NSURLConnectionDataDelegate // // HttpDemo.h // My ...

  6. Robotium API -- 等待执行的方法sleep、waitFor

    测试中经常出现明明有控件或者文本,但是由于界面没有载入完成或者其他原因导致assert判断的结果失败.或者两次执行,一次成功,一次失败的情况.所以需要加入这些等待某些控件或者文本载入的方法,以加强程序 ...

  7. spring mvc事务注解

    @Transactional(noRollbackFor=RuntimeException.class)方法事务说明@Transactional(RollbackFor=Exception.class ...

  8. DORIS-软件网址

    DORIS下载网址:http://doris.tudelft.nl/ Doris软件最新的信息总可以在这个网址上查到:http://enterprise.tudelft.nl/doris/

  9. [CSS3] Interactive Pseudo-Classes :link :visited :hover :active

    The interactive pseudo-classes for links (and buttons) allow us to make sure the user knows what ele ...

  10. Zend Studio 10正式版破解(2013-02-26更新)

    Zend Studio 10正式版注册破解(2013-02-26完成更新) 1.以下方法仅供技术交流学习,请勿非法使用,如长期使用请支持购买正版. 2.若你还没有最新安装程序? ZendStudio ...