DBUtils开源JDBC类库,对JDBC简单封装(作用是:简化编码工作量,同时不会影响程序的性能)
DBUtils:提高了程序的性能,编程更加简便
架包
mysql-connector-java-jar
commons-dbcp-1.4jar
commons-pool-1.5.5jar
commons-dbutils-jar导进去
-------------------------------------------------------------------------------
//数据库连接池:三个开源的架包导进去
数据库连接池连接代码(其方法在TestJDBC()类中):
public Connection testBasicDataSource() throws Exception{
BasicDataSource dataSource=null;
//1. 创建DBCP数据源实例
dataSource=new BasicDataSource();
//2.为数据源实例指定必须的属性
//driver=com.mysql.jdbc.Driver
//jdbcUrl=jdbc:mysql://localhost:3306/lxn
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/lxn");
dataSource.setUsername("root");
dataSource.setPassword("lxn123");
//指定数据源的一些可选的属性
dataSource.setInitialSize(10);//指定数据库连接池中初始化连接的个数
dataSource.setMaxActive(50);//指定最大的连接数:同一时刻可以向数据库同时申请的连接数
dataSource.setMinIdle(10);//指定最小连接数:在数据库连接池空闲状态下,在连接池中最少连接数
dataSource.setMaxWait(1000*5);//等待数据库连接池分配连接最长时间,单位为毫秒,超出时间,抛出异常
Connection connection=dataSource.getConnection();
return connection;
}
--------------------------------------------------------------------------------------------------------
DBUtils里面的各种方法:
/*
* DBUtils:
* */
public class DBUtiles {
/*
*测试QueryRunner类的update方法,可使实现增删改的功能;
*QueryRunner的query方法的返回值取决于其resultsethandller的返回值
*
* */
TestJDBC t=new TestJDBC();
@Test
/*
* ScalarHandler:把结果解转为一个数值(可以是任意数据类型,字符串,date等)返回
* */
public void testScalarHandler() throws Exception{
Connection connection=null;
QueryRunner queryRunner=new QueryRunner();
try {
//获取数据库连接池的方法
connection=t .testBasicDataSource();
String sql="select name from customer where id=?";
//new MapHandler()此方法输出一个结果的键值对;
Object result=
queryRunner.query(connection, sql,new ScalarHandler(),35);
System.out.println(result);
} catch (Exception e) {
e.printStackTrace();
}finally {
close(connection, null, null);
}
}
========================================================
/*
* MapListHanlder:将结果集转为一个map的list
* map:对一个查询的一条记录;键,是列的属性名,值,是键所对应属性名的值; 键不是列的别名
* 而MapListBanlder:返回多条记录的对应的map的集合
* */
public void testMapListHandler() throws Exception{
Connection connection=null;
QueryRunner queryRunner=new QueryRunner();
try {
//获取数据库连接池的方法
connection=t.testBasicDataSource();
String sql="select id,name,email,birth from customer";
//new MapHandler()此方法输出一个结果的键值对;
List<Map<String, Object>> result=
queryRunner.query(connection, sql,new MapListHandler());
System.out.println(result);
} catch (Exception e) {
e.printStackTrace();
}finally {
close(connection, null, null);
}
}
======================================================
/*
* MapHanlder:返回sql对应的第一条记录对应的map对象
* 输出的是键值对:键,是列的属性名,值,是键所对应属性名的值;
* 键不是列的别名,
* */
public void testMapHandler() throws Exception{
Connection connection=null;
QueryRunner queryRunner=new QueryRunner();
try {
//获取数据库连接池的方法
connection=t.testBasicDataSource();
String sql="select id,name,email,birth from customer";
//new MapHandler()此方法输出一个结果的键值对;
Map<String, Object> map=
queryRunner.query(connection, sql,new MapHandler());
System.out.println(map);
} catch (Exception e) {
e.printStackTrace();
}finally {
close(connection, null, null);
}
}
==================================================================
/*
* BeanListHanlder:把结果集转换为一个list,该list不为空,但可能为空集合(size(),方法返回为0)
* 若sql语句的确能够查到记录,list存放创建BeanListHanlder传入的class对象对应的对象
* */
public void testBeanListHandler() throws Exception{
Connection connection=null;
QueryRunner queryRunner=new QueryRunner();
try {
//获取数据库连接池的方法
connection=t.testBasicDataSource();
String sql="select id,name,email,birth from customer";
//BeanListHandler(Customer.class)此方法输出全部结果集
List<Customer> list=
queryRunner.query(connection, sql,new BeanListHandler(Customer.class));
System.out.println(list);
} catch (Exception e) {
e.printStackTrace();
}finally {
close(connection, null, null);
}
}
============================================================
/*
* BeanHanlder:把结果集的第一条记录转为创建BeanHanlder对象时转入的Class参数对应的对象
* */
public void testBeanHandler() throws Exception{
Connection connection=null;
QueryRunner queryRunner=new QueryRunner();
try {
//获取数据库连接池的方法
connection=t.testBasicDataSource();
//11:String sql="select id,name,email,birth from customer where id=?";
String sql="select id,name,email,birth from customer";
//new BeanHandler(Customer.class)此方法只输出一个结果
Customer customer=
queryRunner.query(connection, sql,new BeanHandler(Customer.class));
//11: Customer customer=
// queryRunner.query(connection, sql,new BeanHandler(Customer.class),35);
System.out.println(customer);
} catch (Exception e) {
e.printStackTrace();
}finally {
close(connection, null, null);
}
}
===============================================================
class MyResultSetHandler implements ResultSetHandler{
@Override
public Object handle(ResultSet resultSet) throws SQLException {
List<Customer> list=new ArrayList<Customer>();
while (resultSet.next()) {
int id=resultSet.getInt(1);
String name=resultSet.getString(2);
String email=resultSet.getString(3);
Date birth=resultSet.getDate(4);
Customer customer=new Customer(id, name, email, (java.sql.Date) birth);
list.add(customer);
}
return list;
}
}
//查询方法
public void testQuery() throws Exception{
QueryRunner queryRunner=new QueryRunner();
Connection connection=null;
try {
//获取数据库连接池,t.testBasicDataSource();是已经建立好的方法
connection=t.testBasicDataSource();
String sql="select id,name,email,birth from customer";
// QueryRunner的query方法的返回值取决于其resultsethandller的返回值
Object obj=queryRunner.query(connection, sql, new MyResultSetHandler());
System.out.println(obj);
} catch (Exception e) {
e.printStackTrace();
}finally {
close(connection, null, null);
}
}
=========================================================
//实现增删改
public void testQueryRunnerUpdate() throws Exception{
//1.创建QueryRunner的实现类
//删除语句
String sql="delete from customer where id in(?,?)";
//修改语句
//String sql="update customer set name='panpan' where id=90";
//增加语句
//String sql="insert into customer values(90,'jianjia','panpan','1992-5-3')";
Connection connection=null;
QueryRunner queryRunner=new QueryRunner();
try {
//调用数据库连接池的方法
connection=t.testBasicDataSource();
//2.使用其update方法实现增删改
queryRunner.update(connection, sql, 32,33);
} catch (Exception e) {
e.printStackTrace();
}finally {
close(connection, null, null);
}
}
=============================================================
//关闭资源的方法
public void close(Connection connection,
PreparedStatement preparedStatement,ResultSet resultSet) throws Exception{
if (resultSet!=null) {
resultSet.close();
}if (preparedStatement!=null) {
preparedStatement.close();
}if (connection!=null) {
connection.close();
}
}
}
DBUtils开源JDBC类库,对JDBC简单封装(作用是:简化编码工作量,同时不会影响程序的性能)的更多相关文章
- Spring jdbc 对象Mapper的简单封装
一般查询实体的时候,都需要这么使用/** * 根据id查询 * * @return */ public Emp queryEmpById(Intege ...
- JDBC【2】-- JDBC工作原理以及简单封装
目录 1. 工作原理 1.1 加载驱动 1.1.1 类加载相关知识 1.1.2 为什么JDK 1.6之后不需要显示加载了? 1.2 驱动加载完成了,然后呢? 2. 简单封装 1. 工作原理 一般我们主 ...
- 初学JDBC,JDBC工具类的简单封装
//工具类不需要被继承 public final class JdbcUtils{ //封装数据库连接参数,便于后期更改参数值 private static String url="jdbc ...
- Apache—dbutils开源JDBC工具类库简介
Apache—dbutils开源JDBC工具类库简介 一.前言 commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,学习成本极低,并且使用 ...
- 利用jdbc简单封装一个小框架(类似DBUtils)
利用jdbc写的一个类似DBUtils的框架 package com.jdbc.orm.dbutils; import java.io.IOException; import java.io.Inpu ...
- DBUtils-对JDBC简单封装的开源工具类库
DBUtils 是对JDBC简单封装的开源工具类 详细介绍地址: https://baike.baidu.com/item/Dbutils/10655914?fr=aladdin 在使用DBUtil ...
- java的jdbc简单封装
在学了jdbc一段时间后感觉自己写一个简单的封装来试试,于是參考的一些资料就写了一下不是多好,毕竟刚学也不太久 首先写配置文件:直接在src下建立一个db.properties文件然后写上内容 < ...
- 1、原生jdbc连接oracle数据库简单介绍
一.jbdc的常用API1.Connection:数据库的链接对象2.statement:数据库sql执行对象3.preparedStatment:sql的预编译处理对象,是statement子接口4 ...
- JDBC(1)简单介绍/数据库的连接
初识JDBC: JDBC是java连接数据库的一个工具,没有这个工具,java将无法和数据库进行连接. JDBC API: JDBC是个“低级”接口,也就是说,他直接用于调用SQL命令. JDBC驱动 ...
随机推荐
- wpf 面试题目
初级工程师 解释什么是依赖属性,它和以前的属性有什么不同?为什么在WPF会使用它?什么是样式什么是模板绑定(Binding )的基础用法解释这几个类的作用及关系: Visual, UIElement, ...
- js 点击展开、收起
//点击展开.收起 window.onload=function(){ var current=document.getElementsByTagName('li')[0]; document.bod ...
- 解决xcode6_beta没有代码提示的方法
在beta版本的xcode6中我们会发现代码提示不怎么好使,但是看一些老外的视频,他们的代码提示却又是赶赶的.这是为什么呢?其实解决办法也很简单.就是在项目中不出现中文字符就好了.有的同学说,我没用中 ...
- How to use Ubuntu Linux in virtual box
安装git : yum install git 查询包: rpm -ql git 打开文件夹目录: nautilus 目录路径
- ACM常用算法及练习(2)
ACM常用算法及练习 知识类型 重要度 容易度 应掌握度 典型题 其他 数据结构(5) 链表 ★★☆ ★★★ ★★☆ 栈 stack ★★★ ★★★ ★★★ HLoj120 ...
- web1
<!DOCTYPE html> <html> <head> <title>web0923</title> <script> fu ...
- [原创]java WEB学习笔记72:Struts2 学习之路-- 文件的上传下载,及上传下载相关问题
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
- Java基础(58):Eclipse中的快捷键大全(转)
Eclipse快捷键大全(转载) Ctrl+1 快速修复(最经典的快捷键,就不用多说了)Ctrl+D: 删除当前行 Ctrl+Alt+↓ 复制当前行到下一行(复制增加)Ctrl+Alt+↑ 复制当前行 ...
- .NET: C#: 获取当前路径
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.X ...
- const修饰
const int A() //const // ====>int A(const this) { //观点1:const是修饰a,但是通过测试,我们发现,b++也不能编译通过 //这说明:co ...