详解待续。。。

DBUtilsTest.java

import java.sql.Connection;
import java.sql.Date;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.MapHandler;
import org.apache.commons.dbutils.handlers.MapListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import org.junit.Test;

import com.kk.jdbc.JDBCTools;

public class DBUtilsTest {

  /*
    * ScalarHandler:把结果集转为一个数值(可以是任意基本数据类型和字符串,Date等)返回
    * */
   @Test
   public void testScalarHandler(){
  
      Connection con = null;
      try {
   
         con=JDBCTools.getConnection();
         String sql = "select count(id) from customers";
         Object result=qr.query(con, sql, new ScalarHandler());
         System.out.println(result);
      } catch (Exception e) {
         e.printStackTrace();
      }finally{
         JDBCTools.release(null, null, con);
      }
   }
 
 
   /*
    * MapListHandler:将结果集转为一个Map的List,
    * Map对应查询的一条记录,键:SQL查询的列名(不是列的别名),值:列的值
    * MapListHandler返回的是多条记录对应的Map的集合
    * */
   @Test
   public void testMapListHandler(){
  
      Connection con = null;
      try {
   
         con=JDBCTools.getConnection();
         String sql = "select name from customers where id=?";
         List<Map<String,Object>> result = (List<Map<String, Object>>) qr.query(con, sql, new MapListHandler());
         System.out.println(result);
      } catch (Exception e) {
         e.printStackTrace();
      }finally{
         JDBCTools.release(null, null, con);
      }
   }
 
   /*
    * MapHandler:返回SQL对应的第一条记录对应的Map对象;
    *   键:SQL查询的列名(不是列的别名)
    *   值:列的值
    * */
   @Test
   public void testMapHandler(){
  
      Connection con = null;
      try {
   
         con=JDBCTools.getConnection();
         String sql = "select id,name,email,birth from customers";
         Map<String,Object> result = (Map<String, Object>) qr.query(con, sql, new MapHandler());
         System.out.println(result);
      } catch (Exception e) {
         e.printStackTrace();
      }finally{
         JDBCTools.release(null, null, con);
      }
   }
 
   /*
    * BeanListHandler:把结果集转为一个List,该List不为空,但可能为空集合(size()方法返回0)
    * 若SQL语句能够查询到记录,List中存放创建BeanListHandler传入的Class对象对应的对象。
    * */
   @Test
   public void testBeanListHandler(){
  
      Connection con = null;
      try {
   
         con=JDBCTools.getConnection();
         String sql = "select id,name,email,birth from customers";
         List<Customer> customers = (List<Customer>) qr.query(con, sql, new BeanListHandler(Customer.class));
         System.out.println(customers);
      } catch (Exception e) {
         e.printStackTrace();
      }finally{
          JDBCTools.release(null, null, con);
      }
   }
 
   /*
    * BeanHandler:把结果集的第一条记录转为创建BeanHandler对象时传入的Class参数对应的对象
    * */
   @Test
   public void testBeanHandler(){
  
      Connection con = null;
      try {
   
         con=JDBCTools.getConnection();
         String sql = "select id,name,email,birth from customers where id=?";
         Customer customer=(Customer) qr.query(con, sql, new BeanHandler(Customer.class), 6);
         System.out.println(customer);
      } catch (Exception e) {
         e.printStackTrace();
      }finally{
          JDBCTools.release(null, null, con);
      }
   }
 
 
 
   // 1、创建QueryRunner的实现类
   QueryRunner qr = new QueryRunner();

  /*
    * QueryRunner的query方法的返回值取决于ResultSetHandler参数的handle方法的返回值
    * */
   @Test
   public void testQuery() {

    Connection con = null;
      class MyResultSetHandler implements ResultSetHandler{

      @Override
         public Object handle(ResultSet rs) throws SQLException {
    
            List<Customer> customers=new ArrayList<>();
            while(rs.next()){
               Integer id=rs.getInt(1);
               String name=rs.getString(2);
               String email=rs.getString(3);
               Date birth=rs.getDate(4);
     
               Customer customer=new Customer(id,name,email,birth);
               customers.add(customer);
            }
            return customers;
         }
      }
  
      try {
         con = JDBCTools.getConnection();
         String sql = "select id,name,email,birth from customers";
         Object ob=qr.query(con, sql, new MyResultSetHandler());
         System.out.println("谢荣康:"+ob);
      } catch (Exception e) {
         e.printStackTrace();
      }finally{
         JDBCTools.release(null, null, con);
      }
   }

   /**
    * 测试 QueryRunner类的update方法(insert 、update、delete)
    */
   @Test
   public void testQueryRunnerUpdate() {

     // 2、使用update方法
      String sql = "delete from customers where id in (?,?)";
      Connection con = null;

    try {
         con = JDBCTools.getConnection();
         qr.update(con, sql, 2, 5);

    } catch (Exception e) {
         e.printStackTrace();
      } finally {
         JDBCTools.release(null, null, con);
      }
   }
}

<十五>JDBC_使用 DBUtils 进行更新、查询操作的更多相关文章

  1. 第十五章、python中的进程操作-开启多进程

    目录 第十五章.python中的进程操作-开启多进程 一.multprocess模块 二.multprocess.process模块 三.Process()对象方法介绍 四.Process()对象属性 ...

  2. USB学习笔记连载(十五):USB固件更新以及安装驱动

    前几篇博客已经把如何更改固件程序和更改USB驱动名称,那么接下来就要把之前生成的 .iic 文件烧录到EEPROM里面去,实现USB的C2启动(笔者使用的是此类型,C2启动). 打开Cypress U ...

  3. <十六>JDBC_使用 DBUtils 编写通用的DAO

    接口 : DAO<T>.java import java.sql.Connection;import java.sql.SQLException;import java.util.List ...

  4. [ExtJS5学习笔记]第三十五节 sencha extjs 5 组件查询方法总结

    一个UI前台组件肯定会比较多,我们通常习惯性的使用ID来获取需要操作的组件,但是这种方法是extjs推荐的么?有没有extjs推荐使用的获取组件的方法呢? 目录 目录 extjs的查询组件的API 查 ...

  5. Python学习第二十五课——Mysql (多表查询)

    多表查询: 内连接查询: 首先:创建两个表一个为tableA,一个为tableB,并且插入数据(代码省略) 同时查询两个表的记录: select * from tableA,tableB; 根据tab ...

  6. UWP开发入门(十五)——在FlipView中通过手势操作图片

    本篇的最终目的,是模拟系统的照片APP可以左右滑动,缩放图片的操作.在实现的过程中,我们会逐步分析UWP编写UI的一些思路和技巧. 首先我们先实现一个横向的可以浏览图片的功能,也是大部分APP中的实现 ...

  7. (十五)Hibernate中的多表操作(5):双向多对多

    Hibernate的双向关联. 对象之间可以相互读取.        双向只针对读取的操作.对于增.删除.改的操作没有任何影响. 案例 : 实现双向多对多 MenuBean.java package ...

  8. FreeSql (十五)查询数据

    FreeSql在查询数据下足了功能,链式查询语法.多表查询.表达式函数支持得非常到位. IFreeSql fsql = new FreeSql.FreeSqlBuilder() .UseConnect ...

  9. 第三百六十五节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的基本查询

    第三百六十五节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的基本查询 1.elasticsearch(搜索引擎)的查询 elasticsearch是功能 ...

随机推荐

  1. MVC 导出Excel 的其中一方法(View导出excel)

    场景:mvc下导出excel 思路:使用View导出excel 步骤: 1.导出标签添加事件 $("#export_A").click(function(){ //省略代码.... ...

  2. 出售Illustrator脚本插件面板(包含面板源码,以及面板上所有的功能源码)

    出售Illustrator脚本插件面板(包含面板源码,以及面板上所有的功能源码) 购买后可提供相应的小修改,以及教你使用往这个多列面里再加上按钮功能! 这套源码可作为工作使用,也可用为新手学习AI脚面 ...

  3. Sublime 3 如何配置SVN插件

    在sublime里面安装svn的插件,就可以在sublime的操作界面里面进行相关svn操作,这样就不用再回到文件系统中,进行相关svn的操作. 1.在进入sublime界面后,点击顶部菜单“Pref ...

  4. ASCII码、Unicode码 转中文

    ASCII码.Unicode码 转中文 在最近工作中遇到了一些汉字编码转换的处理,可以通过正则表达式及转换字符来实现转成中文 Unicode转换示例 通常为10位编码, 通过digit参数传入 pri ...

  5. 把 excel 和 mysq l数据库相互转换

    不用代码轻松搞定,参考http://jingyan.baidu.com/article/fc07f9891cb56412ffe5199a.html 1.excel 转 mysql a.首先确认你的数据 ...

  6. 鼠标右击.exe的程序出现闪退(桌面重启)怎么办

    桌面鼠标右击,然后点NVIDIA控制面板(或者按windows+S组合键,在底下输入NVIDIA,然后点NVIDIA控制面板)   好了,然后任意找个文件试试...如图,问题完美解决  

  7. c#_图表之zeGraph

    关于图表控件: http://blog.csdn.net/sgear/article/details/1449025 其中zedGraph的基本方法及属性介绍: http://wenku.baidu. ...

  8. PHP socket上传文件图片

    最近了解了下下socket方面的东西,想做一个socket上传文件的例子. 在网上搜了搜代码执行后,图片数据传输了一半,图片的下半部分是灰色的.然后就自己仿着搜来的代码和php.net 中socket ...

  9. python学习笔记(5)--迭代器,生成器,装饰器,常用模块,序列化

    生成器 在Python中,一边循环一边计算的机制,称为生成器:generator. 如: >>> g = (x * x for xin range(10)) >>> ...

  10. 让tomcat启动更快的设置

    http://wiki.apache.org/tomcat/HowTo/FasterStartUp#Entropy_Source 关于随机数的"熵源"(entropy source ...