具體實作步驟:
1,使用C3P0連接配接池--這裡使用在src根目錄下建立名為c3p0-config.xml的檔案。
<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
<!-- 這是預設配置資訊 -->
<default-config>
<!-- 連接配接四大參數配置 -->
<property name="jdbcUrl">jdbc:mysql://localhost:3306/mydb1</property>
<property name="driverClass">com.mysql.jdbc.Driver</property>
<property name="user">root</property>
<property name="password">123</property>
<!-- 池參數配置 -->
<property name="acquireIncrement">3</property>
<property name="initialPoolSize">10</property>
<property name="minPoolSize">2</property>
<property name="maxPoolSize">10</property>
</default-config>
<!-- 專門為oracle提供的配置資訊 -->
<named-config name="oracle-config">
<property name="jdbcUrl">jdbc:mysql://localhost:3306/mydb1</property>
<property name="driverClass">com.mysql.jdbc.Driver</property>
<property name="user">root</property>
<property name="password">123</property>
<property name="acquireIncrement">3</property>
<property name="initialPoolSize">10</property>
<property name="minPoolSize">2</property>
<property name="maxPoolSize">10</property>
</named-config>
</c3p0-config>
2.建立一個JDBCUtils類,為其他類提供資料庫連接配接對象或者資料庫連接配接池(在QueryRunner中會用到資料庫連接配接池)
package com.c3p0.jdbc;
import java.sql.Connection;
import java.sql.SQLException;
import javax.sql.DataSource;
import com.mchange.v2.c3p0.ComboPooledDataSource;
/**
* 注意必須使用c3p0-config.xml的配置方式。将c3p0-config.xml檔案放在src根目錄下。
* 預設配置。
*
* */
public class JDBCUtils {
private static ComboPooledDataSource ds=new ComboPooledDataSource();
/**
* 使用連接配接池傳回一個連接配接對象
* */
public static Connection getConnection() throws SQLException{
return ds.getConnection();
}
/**
* 傳回一個連接配接池對象。
*
* */
public static DataSource getDataSource(){
return ds;
}
}
3.編寫操作資料庫的類
package com.c3p0.demo1;
import java.sql.SQLException;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.junit.Test;
import com.c3p0.jdbc.JDBCUtils;
public class Demo2 {
/**
* 查詢記錄
* @throws SQLException
*
* */
@Test
public void fun1() throws SQLException{
//建立QueryRunner,需要提供資料庫連接配接池;
QueryRunner qr=new QueryRunner(JDBCUtils.getDataSource());
//給出sql模闆
String sql="select * from tb_stu where number=?";
//給出參數
Object[] params={"stu_001"};
//執行Query,需要給出結果集處理器,即ResultHandler的實作類對象
//我們給的是BeanHandler,他實作了ResultSetHandler
//它需要一個類型,然後他會把rs中的資料封裝到指定類型的javabean對象中,然後傳回javabean.
Stu stu=qr.query(sql, new BeanHandler<Stu>(Stu.class),params);
System.out.println(stu);
}
/**
* 插入新的一條記錄
* @throws SQLException
*
* */
@Test
public void fun2() throws SQLException{
QueryRunner qr=new QueryRunner(JDBCUtils.getDataSource());
String sql="insert into tb_stu values(?,?,?,?,?)";
Object[] params={"stu_003","wangwu",20,"female","dancing"};
int count=qr.update(sql, params);
System.out.println("count:"+count);
}
}
另外,還用到了JavaBean對象Stu
package com.c3p0.demo1;
public class Stu {
private String number;
private String name;
private int age;
private String gender;
private String hobby;
public String getNumber() {
return number;
}
public void setNumber(String number) {
this.number = number;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
public String getHobby() {
return hobby;
}
public void setHobby(String hobby) {
this.hobby = hobby;
}
public Stu(String number, String name, int age, String gender, String hobby) {
this.number = number;
this.name = name;
this.age = age;
this.gender = gender;
this.hobby = hobby;
}
public Stu() {
super();
// TODO Auto-generated constructor stub
}
@Override
public String toString() {
return "Stu [number=" + number + ", name=" + name + ", age=" + age
+ ", gender=" + gender + ", hobby=" + hobby + "]";
}
}
使用這種方式:
(1)将增删改操作簡化了,即同時使用一個模闆即可,隻需修改sql語句和參數即可;
(2)查詢結果直接可以通過ResultSetHandler的實作類封裝成JavaBean對象。
解析common-dbutils.jar:
QueryRunner對象
方法:
update方法:
--》int update(String sql,Object... params):可執行增删改語句
Query方法(泛型):
--》T Query(String sql,ResultSetHandler rsh,Object...params):可執行查詢
他會先得到ResultSet,然後調用rsh的handle()把rs轉換成需要的類型!
ResultSetHandler接口的實作類:
(1)BeanHandler(單行)--》構造器需要一個Class類型的參數,用來把一行結果轉換成指定類型的JavaBean對象;
(2)BeanListHandler(多行)--》構造器也是需要一個Class類型的參數,用來把一行結果集轉換成一個javaBean,那麼多行就是多個JavaBean對象,組合成一個List對象。
(3)MapHandler(單行)把一行結果及轉換成Map對象
例如:一行記錄為
sid sname age gender
001 zhangsan 20 male
那麼轉換成Map就是:
{sid:001,sname:zhangan,age:20,gender:male}
(4)MapListHandler(多行)--》把一行記錄用一個Map裝起來,那麼多航記錄就是多個Map,即List<Map>
(5)ScalarHandler(單行單列)--》通常用于select count(*)from tb_stu語句。結果集是單行單列的,傳回一個object。
package com.c3p0.demo1;
import java.sql.SQLException;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
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.MapHandler;
import org.apache.commons.dbutils.handlers.MapListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import org.junit.Test;
import com.c3p0.jdbc.JDBCUtils;
public class Demo2 {
/**
* 查詢記錄
* @throws SQLException
* 單行結果集處理器:
* (1)BeanHandler單行結果集處理器。
* (2)MapHandler單行結果集處理器
* */
@Test
public void fun1() throws SQLException{
//建立QueryRunner,需要提供資料庫連接配接池;
QueryRunner qr=new QueryRunner(JDBCUtils.getDataSource());
//給出sql模闆
String sql="select * from tb_stu where number=?";
//給出參數
Object[] params={"stu_001"};
//執行Query,需要給出結果集處理器,即ResultHandler的實作類對象
//我們給的是BeanHandler,他實作了ResultSetHandler
//它需要一個類型,然後他會把rs中的資料封裝到指定類型的javabean對象中,然後傳回javabean.
Stu stu=qr.query(sql, new BeanHandler<Stu>(Stu.class),params);//(1)使用BeanHandler單行結果集處理器。
Map map=qr.query(sql, new MapHandler(),params);//(2)使用MapHandler單行結果集處理器
System.out.println(map);
}
/**
* 查詢記錄
* 結果集多行處理器:
* BeanListHandler多行結果集處理器
* MapListHandler多行結果集處理器
* 沒有參數就不用定義Object[] params={}。
* */
@Test
public void fun1_1() throws SQLException{
//建立QueryRunner,需要提供資料庫連接配接池;
QueryRunner qr=new QueryRunner(JDBCUtils.getDataSource());
//給出sql模闆
String sql="select * from tb_stu";
//給出參數
//Object[] params={};
/*使用BeanListHandler*/
List<Stu> list1=qr.query(sql, new BeanListHandler<Stu>(Stu.class));
Iterator<Stu> it=list1.iterator();
while(it.hasNext()){
Stu s=it.next();
System.out.println(s.toString());
}
System.out.println("-----------------------------------");
/*使用MapListHandler*/
List<Map<String, Object>> list2=qr.query(sql, new MapListHandler());
Iterator<Map<String, Object>> it1=list2.iterator();
while(it1.hasNext()){
Map<String,Object> map=it1.next();
System.out.println(map);
}
}
/**
* 查詢記錄
* 單行單列結果
* ScalarHandle
* @throws SQLException
* */
@Test
public void fun3() throws SQLException{
QueryRunner qr=new QueryRunner(JDBCUtils.getDataSource());
String sql="select count(*) from tb_stu";
Object obj=qr.query(sql, new ScalarHandler());
System.out.println(obj.toString());
}
/**
* 插入新的一條記錄
* @throws SQLException
*
* */
@Test
public void fun2() throws SQLException{
QueryRunner qr=new QueryRunner(JDBCUtils.getDataSource());
String sql="insert into tb_stu values(?,?,?,?,?)";
Object[] params={"stu_003","wangwu",20,"female","dancing"};
int count=qr.update(sql, params);
System.out.println("count:"+count);
}
}