DbUtils使用方法

http://blog.sina.com.cn/s/blog_633c77c40100sy6h.html




DbUtils是apache上的一个开源工具包.对数据库的操作进行了二次的封装.

DbUtils提供了三个包,分别是:
org.apache.commons.dbutils;
org.apache.commons.dbutils.handlers;
org.apache.commons.dbutils.wrappers;
org.apache.commons.dbutils
DbUtils 关闭链接等操作
QueryRunner 进行查询的操作
 
org.apache.commons.dbutils.handlers
ArrayHandler :将ResultSet中第一行的数据转化成对象数组
ArrayListHandler将ResultSet中所有的数据转化成List,List中存放的是Object[]
BeanHandler :将ResultSet中第一行的数据转化成类对象
BeanListHandler :将ResultSet中所有的数据转化成List,List中存放的是类对象
ColumnListHandler :将ResultSet中某一列的数据存成List,List中存放的是Object对象
KeyedHandler :将ResultSet中存成映射,key为某一列对应为Map。Map中存放的是数据
MapHandler :将ResultSet中第一行的数据存成Map映射
MapListHandler :将ResultSet中所有的数据存成List。List中存放的是Map
ScalarHandler :将ResultSet中一条记录的其中某一列的数据存成Object
 
org.apache.commons.dbutils.wrappers
SqlNullCheckedResultSet :对ResultSet进行操作,改版里面的值
StringTrimmedResultSet :去除ResultSet中中字段的左右空格。Trim()
 

可以去网上下载官方的测试以及使用实例.今天下午自己闲没有事做,自己写了一些常用方法的测试数据.
首先我用的是mysql数据库,创建一个测试用的表,具体的sql语句如下:
DROP TABLE IF EXISTS `person`;
CREATE TABLE `person` (
   `id` int(11) NOT NULL AUTO_INCREMENT,
   `name` varchar(10) DEFAULT NULL,
   `age` int(11) DEFAULT NULL,
   `address` varchar(100) DEFAULT NULL,
   PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

然后创建表对应的javabean:具体的代码如下:
package net.ybx.test;

public class Person {

public int id;
public String name;
public int age;
public String address;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
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 getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public String toString(){
return "id="+id+"    name="+name+"   address="+address+"   age="+age;
}
}
然后具体的测试类如下:
package net.ybx.test;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.List;

import org.apache.commons.dbutils.DbUtils;
import org.apache.commons.dbutils.ProxyFactory;
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.ScalarHandler;
import org.apache.commons.dbutils.wrappers.SqlNullCheckedResultSet;
import org.apache.commons.dbutils.wrappers.StringTrimmedResultSet;

public class DbUtilsTest {

private static final String DRIVERCLASS = "com.mysql.jdbc.Driver";
private static final String CONNECTURL = "jdbc:mysql://localhost/test?useUnicode=true&characterEncoding=utf-8";
private static final String USER = "root";
private static final String PASSWORD = "3769221";
public static Connection conn;

public static void main(String[] args) {
// TODO Auto-generated method stub
DbUtils DB = new DbUtils();
// 加载数据库mysql的jdbc驱动
DB.loadDriver(DRIVERCLASS);
PreparedStatement stmt = null;
QueryRunner qr = new QueryRunner();
try {
conn = DriverManager.getConnection(CONNECTURL, USER, PASSWORD);


// 获得PreparedStatement对象
stmt = conn
.prepareStatement("insert into person(name,age,address) values(?,?,?)");
Person person = new Person();
person.setAddress("上海");
person.setName("南信大");
person.setAge(50);
qr.fillStatementWithBean(stmt, person, new String[] { "name",
"age", "address" });
stmt.execute();
// 删除数据;
qr
.update(conn, "delete from person where id=?",
new Object[] { 4 });
// 查询一个bean数据

person = (Person) qr.query(conn, "select * from person where id=?",
new Object[] { 10 }, new BeanHandler(Person.class));
System.out.println("查询出的数据为:" + person.toString());
// 查询一个List
List list = (List) qr.query(conn,
"select * from person", new BeanListHandler(Person.class));
// 遍历一个list
for (int i = 0; i < list.size(); i++)
System.out.println(list.get(i).toString());
// 返回刚刚插入数据的ID(自动递增的)
Long id = (Long) qr.query(conn, "select last_insert_id()",
new ScalarHandler(1));
System.out.println("最新自动增加的值为:" + id.longValue());

// SqlNullCheckedResult 测试
System.out
.println("-------------------------------一道华丽的分界线-----------------------");
Statement stat = conn.createStatement();
ResultSet rs = stat
.executeQuery("select * from person where id=18");
SqlNullCheckedResultSet wrapper = new SqlNullCheckedResultSet(rs);
wrapper.setNullString("------N/A------");
wrapper.setNullInt(1000);
rs = ProxyFactory.instance().createResultSet(wrapper);
while (rs.next())
System.out.println(rs.getInt("id") + rs.getString("address")
+ "    " + rs.getInt("age"));
System.out
.println("--------------------又是一个华丽的分割线----------------");
rs = stat.executeQuery("select * from person where id=17");
while (rs.next()) {
System.out.println("长度为:"+rs.getString(2).length());
rs = StringTrimmedResultSet.wrap(rs);
System.out.println("现在长度为:"+rs.getString(2).length());
System.out.println(rs.getString(2));
}
} catch (SQLException e) {
// TODO Auto-generated catch block
DB.rollbackAndCloseQuietly(conn);
e.printStackTrace();
} finally {
DbUtils.closeQuietly(conn);
DbUtils.closeQuietly(stmt);

}

}

}

具体的一些截图如下: DbUtils使用方法_第1张图片

DbUtils使用方法_第2张图片

DbUtils使用方法_第3张图片


具体的代码可以到下面的地址去下载:http://www.kuaipan.cn/file/id_18825567507841057.html

DbUtils对于一些小的项目作为公共类可以提高开发效率,可以简化DAO层的代码,同时对于一些查询出的ResultSet可以很简单的做一些转化.比如转化为bean,array,list,map之类的.是操作变得比较的简单.



你可能感兴趣的:(DbUtils使用方法)