一、DBUtils

1.DBUtils的简介

Commons DbUtils是Apache组织提供的一个对JDBC进行简单封装的开源工具类库,使用它能够简化JDBC应用程序的开发,同时也不会影响程序的性能。

2.DBUtils中的API的概要介绍

QueryRunner类:sql操作的核心类 这个对象内部封装着操作数据的方法

ResultSetHandler接口:代表结果集到实体的映射封装的功能

为什么是接口:具体封装的规则不知道 要根据实体业务进行自行操作

DButils类:主要是关于数据库的关闭 事务的提交相关的方法

3.QueryRunner的API详解

注意:在使用DBUtils之前 导入的jar包

1)数据库驱动

2)连接池的jar

3)DBUtils的jar

(1)怎样创建QueryRunner

有两种方式可以创建QueryRunner

第一种无参:new QueryRunner();

一般情况下 结合事务操作一起使用

第二种有参:new QueryRunner(DataSource);

一般情况下 不需要事务控制的时候使用

注意:程序中操作sql时 必须得有Connection对象,有数据源参数的构造方法会自动从数据源中获得一个Connection对象操作数据库。无参的构造方法在创建QueryRunner时没有提供Connection的对象信息,在指定操作sql的方法时也得传入Connection。

QueryRunner中的方法

batch

update

query

(2)更新数据的操作(单条sql执行)

update操作:

update方法有三个参数 是通过这三个参数的组合 形成多个方法

Connection:数据库的连接对象 与无参的new QueryRunner()一起使用

sql:要执行sql语句  是必须有的

params:代笔占位符的实际的参数

通过上述参数可以组成哪些方法

update(Connection,sql,params);

update(Connection,sql);

update(sql,params);

update(sql);

     @Test
public void test1() throws SQLException{
//需求:修改products表中的id=100的商品的category为 生活
//1、创建QueryRunner
QueryRunner runner = new QueryRunner(DataSourceUtils.getDataSource());
//2、执行sql
String sql = "update products set category=? where id=?";
int update = runner.update(sql, "生活","100");
System.out.println(update);
}

(3)更新数据的操(批量sql执行)

batch操作---同时执行sql结构相同的多条语句

参数:

Connection:数据库的连接对象 与无参的new QueryRunner()一起使用

sql:要执行sql语句  是必须有的

params:二维数组

一维代表是指定的sql

二维代表sql中的占位符的实际参数

例如:

sql:insert into products values(?,?,?);

param:

{

  {500,ios入门,15},

  {600,C#入门,28},

  {700,ruby入门,45},

  {800,hadoop入门,99}

}

insert语句执行几次:4次  每一次执行3个参数

需求:向products表中批量插入2条数据

 //1、创建QueryRunner对象
QueryRunner runner = new QueryRunner(DataSourceUtils.getDataSource());
//2、执行sql
String sql = "insert into products values(?,?,?,?,?,?,?)";
//Object[][] params = new Object[2][7];
//params[0][0]="500";
Object[][] params = {
{"500","ruby入门",89,"感性",800,"bookcover/105.jpg","好书啊好书"},
{"600","hadoop入门",89,"感性",800,"bookcover/106.jpg","好书啊好书"}
};
int[] batch = runner.batch(sql, params);
//{1,1}
for(int i:batch){
System.out.println(i);
}

(4)查询的操作query

query方法执行select语句

参数:

Connection:数据库的连接对象 与无参的new QueryRunner()一起使用

sql:要执行sql语句  是必须有的

params:代笔占位符的实际的参数

ResultSetHandelr:结果集封装的功

     @Test
public void test1() throws SQLException{
//1、创建QueryRunner
QueryRunner runner = new QueryRunner(DataSourceUtils.getDataSource());
//2、执行sql语句
String sql = "select * from products";
List<Product> query = runner.query(sql, new ResultSetHandler<List<Product>>() {
@Override
public List<Product> handle(ResultSet rs) throws SQLException {
//写自己的封装的逻辑
List<Product> list = new ArrayList<Product>();
while(rs.next()){
Product pro = new Product();
pro.setId(rs.getString("id"));
pro.setName(rs.getString("name"));
pro.setCategory(rs.getString("category"));
pro.setDescription(rs.getString("description"));
pro.setImgurl(rs.getString("imgurl"));
pro.setPnum(rs.getInt("pnum"));
pro.setPrice(rs.getDouble("price"));
list.add(pro);
}
return list;
} }); System.out.println(query);
}

二、ResultSetHandler接口的实现类

BeanListHandler:返回是List<T>

BeanHandler:返回的是T

MapListHandler:返回是List<Map<String,Object>>

MapHandler:返回是Map<String,Object>

ScalarHandler:返回的是一个object获得的是一个值 是查出的虚拟表的左上角的 值,常用在聚合函数查询中

---------------------------------------------------------------

ArrayListHandler:List<Object[]>

ArrayHandler:Object[]

ColumnListHandler:List<Object> 查询的是结构的某一列的数据集合

KeyedHandler:返回值Map<Object,Map<String,Object>>

{

  200={id=200, category=生活, price=78.0, pnum=120, description=好书一本, name=android入门经典, imgurl=bookcover/102.jpg},

  100={id=100, category=生活, price=88.0, pnum=100, description=好书一本, name=java入门经典, imgurl=bookcover/101.jpg}

}

DbUtils工具类:工具类,包括事务的提交,回滚和资源的关闭的工具方法,使用不多

Java实战之04JavaWeb-06DBUtils的更多相关文章

  1. 「小程序JAVA实战」springboot的后台搭建(31)

    转自:https://idig8.com/2018/08/29/xiaochengxujavashizhanspringbootdehoutaidajian31/ 根据下面的图,我们来建立下对应的sp ...

  2. Java实战:教你如何进行数据库分库分表

    摘要:本文通过实际案例,说明如何按日期来对订单数据进行水平分库和分表,实现数据的分布式查询和操作. 本文分享自华为云社区<数据库分库分表Java实战经验总结 丨[绽放吧!数据库]>,作者: ...

  3. java实战之解析xml

    在java中解析xml有现成的包提供方法,常用的有四类:Dom,JDom,Sax以及Dom4j.其中前者是java中自带的,后三者需要大家从开源诸如sourceforge这样的网站下载jar包,然后在 ...

  4. Java归去来第4集:java实战之Eclipse中创建Maven类型的SSM项目

    一.前言 如果还不了解剧情,请返回第3集的剧情          Java归去来第3集:Eclipse中给动态模块升级 二.在Eclipse中创建Maven类型的SSM项目 2.1:SSM简介 SSM ...

  5. Lucene之Java实战

    1.导包 2.索引的创建 2.1首先,我们需要定义一个词法分析器. Analyzer analyzer = new IKAnalyzer();//官方推荐 Analyzer analyzer = ne ...

  6. 【Java实战】源码解析Java SPI(Service Provider Interface )机制原理

    一.背景知识 在阅读开源框架源码时,发现许多框架都支持SPI(Service Provider Interface ),前面有篇文章JDBC对Driver的加载时应用了SPI,参考[Hibernate ...

  7. 添物零基础到大型全栈架构师 Java实战及解析(实战篇)- 概述

    ​ 实战篇是在基础之上,进一步提升的内容.通过实战篇可以深入理解Java相关框架和库的使用,能够独立开发小模块,或者按照架构师的指导进行代码编写和完善. 主要讲解核心框架和库的使用和使用场景介绍.通过 ...

  8. Zookeeper API for JAVA实战与应用

    package com.zookeeper.watcher; import java.util.List; import java.util.concurrent.CountDownLatch; im ...

  9. Java实战equals()与hashCode()

    一.equals()方法详解 equals()方法在object类中定义如下: 代码 public boolean equals(Object obj) { return (this == obj); ...

  10. JAVA 实战练习

    1.判断变量是否为奇数偶数. package com.JAVA; import java.util.Scanner; public class text { public static void ma ...

随机推荐

  1. TFS的使用

    1.http://www.kwstu.com/ArticleView/kwstu_201462311500744

  2. uLua学习笔记(一):uLua安装及上手

    uLua下载:http://www.ulua.org/ VS2012/2013的用于编写Lua的插件:https://babelua.codeplex.com/或http://unknownworld ...

  3. DRM加密技术是怎么一回事

    有时我们在播放从网上下载的影视文件时会要求输入用户许可证,否则就不能正常播放,听说是用了一种DRM技术,请简单介绍一下. 答:通常这是利用了多媒体DRM加密技术保护版权(DRM是数字权限管理技术的缩写 ...

  4. Flash Builder 创建CSS

    1.global 选择器将样式应用于所有控件 Ÿ 在 Flash Builder 中创建新MXML 文件并切换到设计模式 Ÿ 属性视图右侧的外观视图可更改外观 Flash Builder 自动创建CS ...

  5. 【07】为多态基类声明virtual析构方法

    1.考虑下面的需要,需要一个工厂方法.工厂方法的规则是:在堆上分配一个子类对象,并返回父类指针.使用完毕,delete父类指针.如果父类的析构方法不是virtual,将直接调用父类的析构方法,导致局部 ...

  6. ThinkPHP CURD方法盘点:data方法

    data方法也是模型类的连贯操作方法之一,用于设置当前要操作的数据对象的值,可能大家不太习惯用这个方法,今天来讲解下如何用好data方法. 用法 写操作 通常情况下我们都是通过create方法或者赋值 ...

  7. [Practical Git] Show who changed a line last with git blame

    When working on a file, we often want to know who made certain changes last; we can use git blame to ...

  8. android学习日记24--Android 菜单开发

    菜单是任何应用程序必不可少的一项.按下Menu键或者长按某个View就会弹出相应菜单,当然前提是应用程序有实现菜单功能. Android平台下的菜单有:Options Menu(选项菜单).Subme ...

  9. 已超过了锁请求超时时段。 (Microsoft SQL Server,错误: 1222)

    操作SQLServer数据库时.遇到这种问题:已超过了锁请求超时时段. (Microsoft SQL Server,错误: 1222) 经过查找材料了解为资源抢占,照成死锁,杀死进程就OK了.详细操作 ...

  10. 设计模式-工厂方法(Demo)

    工厂方法 工厂方法跟简单工厂一样.都是创建型的设计模式.他攻克了简单工厂的违背开放封闭的缺点. 故事 主人--人家做饭好累的.女仆抱着我大腿说着.自从上次把她买进家.没做了几次饭就喊累--看着她那出处 ...