Common Dbutils是操作数据库的组件,对传统操作数据库的类进行二
次封装,可以把结果集转化成List。


DBUtils包括3个包:
org.apache.commons.dbutils
org.apache.commons.dbutils.handlers
org.apache.commons.dbutils.wrappers
DBUtils封装了对JDBC的操作,简化了JDBC操作,可以少写代码。
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()

主要方法:


DbUtils类:启动类

ResultSetHandler接口:转换类型接口

MapListHandler类:实现类,把记录转化成List

BeanListHandler类:实现类,把记录转化成List,使记录为JavaBean类型的对象

Qrery Runner类:执行SQL语句的类


建立三个Java文件

命名为BeanListExample.java

Guestbook.java

MapListExample.java

源码:

BeanListExample.java


Code
package
com.sy;

import
org.apache.commons.dbutils.DbUtils;
import
org.apache.commons.dbutils.QueryRunner;
import
org.apache.commons.dbutils.handlers.BeanListHandler;
import
java.sql.Connection;
import
java.sql.DriverManager;
import
java.sql.SQLException;
import
java.util.List;


public
class
BeanListExample
{

public
static
void
main(String[] args)
{
Connection conn
=
null
;
String url
=
"
jdbc:mysql://localhost:3306/people
"
;
String jdbcDriver
=
"
com.mysql.jdbc.Driver
"
;
String user
=
"
root
"
;
String password
=
"
hicc
"
;

DbUtils.loadDriver(jdbcDriver);

try
{
conn
=
DriverManager.getConnection(url, user, password);
QueryRunner qr
=
new
QueryRunner();
List results
=
(List) qr.query(conn,
"
select id,name from guestbook
"
,
new
BeanListHandler(Guestbook.
class
));

for
(
int
i
=
0
; i
<
results.size(); i
++
)
{
Guestbook gb
=
(Guestbook) results.get(i);
System.out.println(
"
id:
"
+
gb.getId()
+
"
,name:
"
+
gb.getName());
}
}
catch
(SQLException e)
{
e.printStackTrace();
 }
finally
{
DbUtils.closeQuietly(conn);
}
}
}

Guestbook.java



Code
package
com.sy;


public
class
Guestbook
{
private
Integer id;
private
String name;


public
Integer getId()
{
return
id;
}
public
void
setId(Integer id)
{
this
.id
=
id;
}
public
String getName()
{
return
name;
}
public
void
setName(String name)
{
this
.name
=
name;
}
}

MapListExample.java


Code
package
com.sy;

import
org.apache.commons.dbutils.DbUtils;
import
org.apache.commons.dbutils.QueryRunner;
import
org.apache.commons.dbutils.handlers.MapListHandler;

import
java.sql.Connection;
import
java.sql.DriverManager;
import
java.sql.SQLException;

import
java.util.List;
import
java.util.Map;


public
class
MapListExample
{

public
static
void
main(String[] args)
{
Connection conn
=
null
;
String url
=
"
jdbc:mysql://localhost:3306/people
"
;
String jdbcDriver
=
"
com.mysql.jdbc.Driver
"
;
String user
=
"
root
"
;
String password
=
"
hicc
"
;

DbUtils.loadDriver(jdbcDriver);

try
{
conn
=
DriverManager.getConnection(url, user, password);
QueryRunner qr
=
new
QueryRunner();
List results
=
(List) qr.query(conn,
"
select id,name from guestmessage
"
,
new
MapListHandler());

for
(
int
i
=
0
; i
<
results.size(); i
++
)
{
Map map
=
(Map) results.get(i);
System.out.println(
"
id:
"
+
map.get(
"
id
"
)
+
"
,name:
"
+
map.get(
"
name
"
));
}
}
catch
(SQLException e)
{
e.printStackTrace();
 }
finally
{
DbUtils.closeQuietly(conn);
}
}
}

使用组建好需要添加commons
-
dbutils
-
1.1
.jar和mysql
-
connector
-
java
-
5.1
.
6
-
bin.jar
两个jar包。


配置完毕!!!

//
另一种方法
//
使用dbutils1.0版本
import
java.util.
*
;
import
java.util.logging.
*
;
import
java.sql.
*
;
import
org.apache.commons.dbutils.
*
;
import
org.apache.commons.dbutils.handlers.
*
;


public
class
TestDBUnits
{

public
static
void
main(String[]args)
throws
Exception
{
TestDBUnits test
=
new
TestDBUnits();

for
(
int
i
=
0
; i
<
1
; i
++
)
{
test.testQuery1();
test.testQuery2();
test.testUpdate();
}
}

public
void
testQuery1()
{

try
{
QueryRunner qr
=
new
QueryRunner() ;
ResultSetHandler rsh
=
new
ArrayListHandler();
String strsql
=
"
select * from test1
"
;
ArrayList result
=
(ArrayList)qr.query(getConnection() ,strsql ,rsh);
//
System.out.print("");
}
catch
(Exception ex)
{
ex.printStackTrace(System.out);
}
}

public
void
testQuery2()
{

try
{
QueryRunner qr
=
new
QueryRunner() ;
ResultSetHandler rsh
=
new
MapListHandler();
String strsql
=
"
select * from test1
"
;
ArrayList result
=
(ArrayList)qr.query(getConnection() ,strsql ,rsh);

for
(
int
i
=
0
; i
<
result.size() ; i
++
)
{
Map map
=
(Map)result.get(i);
//
System.out.println(map);
}
//
System.out.print("");
}
catch
(Exception ex)
{
ex.printStackTrace(System.out);
}
}

public
void
testUpdate()
{

try
{
QueryRunner qr
=
new
QueryRunner() ;
ResultSetHandler rsh
=
new
ArrayListHandler();
String strsql
=
"
insert test1(page ,writable ,content)values('ttt','ttt','faskldfjklasdjklfjasdklj')
"
;
qr.update(getConnection() ,strsql);
//
System.out.print("");
}
catch
(Exception ex)
{
ex.printStackTrace(System.out);
}
}
private
Connection getConnection()
throws
InstantiationException,
 IllegalAccessException, ClassNotFoundException, SQLException
{
String strDriver
=
"
org.gjt.mm.mysql.Driver
"
;
String strUrl
=
"
jdbc:mysql://localhost:3306/test
"
;
String strUser
=
"
root
"
;
String strPass
=
""
;
Class.forName(strDriver).newInstance();
return
DriverManager.getConnection(strUrl, strUser, strPass);
}
}
|
|
随笔:8
文章:23
评论:45
引用:0
| 日 | 一 | 二 | 三 | 四 | 五 | 六 |
---|
26 | 27 | 28 | 29 | 30 | 31 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
|
留言簿(5)
文章分类(25)
最新随笔
搜索
积分与排名
最新评论

|
|