Java实战之04JavaWeb-06DBUtils

一、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);

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

(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 //1、创建QueryRunner对象
 2         QueryRunner runner = new QueryRunner(DataSourceUtils.getDataSource());
 3         //2、执行sql
 4         String sql = "insert into products values(?,?,?,?,?,?,?)";
 5         //Object[][] params = new Object[2][7];
 6         //params[0][0]="500";
 7         Object[][] params = {
 8                 {"500","ruby入门",89,"感性",800,"bookcover/105.jpg","好书啊好书"},
 9                 {"600","hadoop入门",89,"感性",800,"bookcover/106.jpg","好书啊好书"}
10         };
11         int[] batch = runner.batch(sql, params);
12         //{1,1}
13         for(int i:batch){
14             System.out.println(i);
15         }

(4)查询的操作query

query方法执行select语句

参数:

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

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

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

ResultSetHandelr:结果集封装的功

 1     @Test
 2     public void test1() throws SQLException{
 3         //1、创建QueryRunner
 4         QueryRunner runner = new QueryRunner(DataSourceUtils.getDataSource());
 5         //2、执行sql语句
 6         String sql = "select * from products";
 7         List<Product> query = runner.query(sql, new ResultSetHandler<List<Product>>() {
 8             @Override
 9             public List<Product> handle(ResultSet rs) throws SQLException {
10                 //写自己的封装的逻辑
11                 List<Product> list = new ArrayList<Product>();
12                 while(rs.next()){
13                     Product pro = new Product();
14                     pro.setId(rs.getString("id"));
15                     pro.setName(rs.getString("name"));
16                     pro.setCategory(rs.getString("category"));
17                     pro.setDescription(rs.getString("description"));
18                     pro.setImgurl(rs.getString("imgurl"));
19                     pro.setPnum(rs.getInt("pnum"));
20                     pro.setPrice(rs.getDouble("price"));
21                     list.add(pro);
22                 }
23                 return list;
24             }
25
26         });
27
28         System.out.println(query);
29     }

二、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工具类:工具类,包括事务的提交,回滚和资源的关闭的工具方法,使用不多

时间: 2024-08-11 03:38:11

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

java实战1——浮点数转人民币读法

为了学习安卓,现在开始从C++角度来学习Java,现在看到了<疯狂java讲义>的第四章,里面有个字符串转人民币的例子,书上没做完,于是把其补充完善.其中最难的部分就是根据零在不同位置,具有不同行为.按照中文读法,有些零要读出,有些零不需要读出.下面将按照两部分进行讲解,首先举一个例子来说明思路,其次给出Java的源代码供参考,并且进行测试.这个问题主要利用字符串数组来解决.我们假定要转换的浮点数整数部分不超过12位. (1) 思路 1.1 分割整数和小数部分 对于一个浮点数,先来看个简单点,

JAVA实战教程_JAVA案例开发之JAVA开发微信二维码大数据开发03

大家好,这次是第三个课时的视频,欢迎大家继续学习. 视频简介:本视频是关于JAVA实战教程,JAVA开发微信二维码大数据系统.这个JAVA开发案例可以协助一些从零基础开始学习JAVA,正处于理论走完实践的路程上的初学者能接触到实际开发项目过程中,在实践当中巩固自己的JAVA方面的知识外,更能在项目案例当中学到解决在JAVA学习或者实践当中遇上问题的一些解决方式.仅供参考!自设交流群:457036818,欢迎一起加入交流. PS:该案例共十个课时,本小节为第二课时 课程原地址:http://www

JAVA实战教程_JAVA案例开发之JAVA开发微信二维码大数据系统02

hello,上一次我们上传了第一个课时的视频,现在当然是上传第二个视频咯. 视频简介:本视频是关于JAVA实战教程,JAVA开发微信二维码大数据系统.这个JAVA开发案例可以协助一些从零基础开始学习JAVA,正处于理论走完实践的路程上的初学者能接触到实际开发项目过程中,在实践当中巩固自己的JAVA方面的知识外,更能在项目案例当中学到解决在JAVA学习或者实践当中遇上问题的一些解决方式.仅供参考!自设交流群:457036818,欢迎一起加入交流. PS:该案例共十个课时,本小节为第二课时 课程原地

java实战系列-实战中MAVEN私服的搭建

 实战中MAVEN私服的搭建 利用maven来管理项目的构建,报告和文档已经成为了我们现在的共识,任何开源软件基本都在使用,当然我们现在的大部分公司也基本都在使用,我把以前使用maven的一些经验在进行加工呈现给大家,希望可以帮助一些当前正在学习maven的初学者们还有刚毕业的学子们! 我会结合Eclipse+nexus+maven的实践来个大家做介绍! Nexus是Maven仓库管理器,虽然我们可以从Maven中央仓库下载所需要的构件(artifact),但这样会让我们的编译过程变得相当的慢

Java实战之路(1):SpringBoot项目中使用Mybatis打印Sql语句

SpringBoot项目中使用Mybatis打印Sql语句 如题,实际项目中使用很多都会用到SpringBoot+Mybatis的经典搭配进行开发,数据库里明明有数据,可是程序运行就是查不到,此时我们在本地Debug时,需要将Mybatis的实际Sql打印出来,看看Sql与我们期望的是否一致,或者将Sql拿到数据库中直接执行,看看结果.这里简单介绍几种实战中的用法. 方法一 properties:在application.properties配置文件中增加如下配置 logging.level.c

java实战之解析xml

在java中解析xml有现成的包提供方法,常用的有四类:Dom,JDom,Sax以及Dom4j.其中前者是java中自带的,后三者需要大家从开源诸如sourceforge这样的网站下载jar包,然后在eclipse中“build path”加载外来的jar文件就行.各自的入门demo可以观看官网文档,听说文档有点晦涩难懂,可以多多google之,园子里有的是资源.接下来主要讲的是如何使用Dom4j解析xml文档. 1.什么是xml 首先从维基百科里盗图一张,解释xml的主要结构——『节点(nod

Java实战应用视频教程之Java算法分析与设计

实战应用Java算法分析与设计(链表.二叉树.哈夫曼树.图.动态规划.HashTable算法)适合人群:中级课时数量:38课时用到技术:Java算法涉及项目:案例应用实战咨询qq:1840215592课程简介:算法分析与设计Java版,是一套实用型算法课程.通过本课程的学习,学员可以掌握以下技术点:线性结构与顺序表.单向链表.循环链表.栈的基本概念.链式堆栈.中缀表达式.队列.链式队列.串.MyString.Brute-Force算法.MySet类实现.矩阵类.递归算法.哈夫曼树.希尔排序.Ha

【Java实战】源码解析为什么覆盖equals方法时总要覆盖hashCode方法

1.背景知识 本文代码基于jdk1.8分析,<Java编程思想>中有如下描述: 另外再看下Object.java对hashCode()方法的说明: /** * Returns a hash code value for the object. This method is * supported for the benefit of hash tables such as those provided by * {@link java.util.HashMap}. * <p> *

Java实战之03Spring-01Spring概述

一.Spring概述 1.Spring是什么? Spring是分层的Java SE/EE应用 full-stack轻量级开源框架,以IoC(Inverse Of Control:反转控制)和AOP(Aspect Oriented Programming:面向切面编程)为内核,提供了展现层Spring MVC和持久层Spring JDBC以及业务层事务管理等众多的企业级应用技术,还能整合开源世界众多著名的第三方框架和类库,逐渐成为使用最多的Java EE企业应用开源框架. 2.Spring的发展历

Java实战之02Hibernate-05检索策略、检索方式

十一.Hibernate的检索策略 1.概述: 查询的时机:什么时候去查? 1 /** 2 * 一张表的检索策略我们称之为: 3 * 类级别的检索策略. 4 * 注意:只要是说类级别的检索策略,就一定不涉及关联对象. 5 * 6 * 类级别检索策略解决的问题: 7 * 1.查询的时机: 8 * 分为两种情况 9 * 立即加载:不管用不用,都马上查询出来 10 * 延迟加载:什么时候用,什么时候去查询.(懒加载,惰性加载) 11 12 * 13 *常用方法: 14 * get: 15 * 永远都是