Apache DbUtils 探秘
听说Apache的DbUtils很好用,而且是对jdbc的简单的封装,所以可以和jdbc一起混搭,多以今天就来尝试一下,关于DbUtils 是如何使用的。
准备
- 数据库: MySQL
- 依赖:
- mysql-connector-java-5.1.7-bin.jar
- apache-commons-dbutils.jar
创建数据库
create table dbutil(
id int(10) not null primary key auto_increment,
name varchar(30) not null
);
# 先插入一条测试语句
insert into dbutil(name) values("Molly");
# 结果如下:
mysql> select * from dbutil;
+----+-------+
| id | name |
+----+-------+
| 1 | Molly |
+----+-------+
1 row in set (0.00 sec)
制作Bean模型
package dbutils;
public class Bean {
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
创建共有数据库连接对象
package dbutils;
import java.sql.Connection;
import java.sql.DriverManager;
public class ConnTools {
private static String DRIVER = "com.mysql.jdbc.Driver";
private static String URL = "jdbc:mysql://localhost:3306/practice";
private static String USER = "root";
private static String PASSWORD = "mysql";
public static Connection getConnection(){
try {
Class.forName(DRIVER);
Connection conn = null;
conn = DriverManager.getConnection(URL, USER, PASSWORD);
if (conn != null) {
return conn;
}
return null;
} catch (Exception e) {
throw new RuntimeException(e.getMessage());
}
}
}
测试代码CRUD
- 首先测试插入语句:
@Test
public void insert() throws Exception {
Connection conn = ConnTools.getConnection();
QueryRunner runner = new QueryRunner();
for (int i = 0; i < 10; i++) {
runner.update(conn, "insert into dbutil(name) values(?)", "Mark"+(1+i));
}
// 记得用完数据库的链接就要及时的关闭!
DbUtils.close(conn);
System.out.println("成功差入10条数据!");
}
结果如下:
mysql> select * from dbutil;
+----+--------+
| id | name |
+----+--------+
| 1 | Molly |
| 4 | Mark1 |
| 5 | Mark2 |
| 6 | Mark3 |
| 7 | Mark4 |
| 8 | Mark5 |
| 9 | Mark6 |
| 10 | Mark7 |
| 11 | Mark8 |
| 12 | Mark9 |
| 13 | Mark10 |
+----+--------+
11 rows in set (0.00 sec)
- 然后是删除语句:
@Test
public void delete() throws Exception {
Connection conn = ConnTools.getConnection();
QueryRunner runner = new QueryRunner();
runner.update(conn, "delete from dbutil where id >= 2");
DbUtils.close(conn);
System.out.println("删除语句成功执行!");
}
结果如下:
mysql> select * from dbutil;
+----+-------+
| id | name |
+----+-------+
| 1 | Molly |
+----+-------+
1 row in set (0.00 sec)
- 再是修改语句
@Test
public void modify() throws Exception {
Connection conn = ConnTools.getConnection();
QueryRunner runner = new QueryRunner();
// 这里使用的是不限参数的那个重载方法!
runner.update(conn, "update dbutil set name = ? where id = ?", "MOLLY", 1);
DbUtils.close(conn);
System.out.println("修改语句执行成功!");
}
结果如下:
mysql> select * from dbutil;
+----+-------+
| id | name |
+----+-------+
| 1 | Molly |
+----+-------+
1 row in set (0.00 sec)
mysql> select * from dbutil;
+----+-------+
| id | name |
+----+-------+
| 1 | MOLLY |
+----+-------+
1 row in set (0.00 sec)
- 再来个查找的方法,
@Test
public void selectOne() throws Exception {
Connection conn = ConnTools.getConnection();
QueryRunner runner = new QueryRunner();
Bean bean = (Bean)runner.query(conn,"select name from dbutil where id = ?",new BeanHandler<Bean>(Bean.class),1);
DbUtils.close(conn);
System.out.println(bean.getName());
}
结果如下:
MOLLY
查找的时候有可能是一下子查找多个,所以再来看一个查找多个的小例子。
由于刚才插入的数据被删除了,所以我们需要先运行一下insert方法来添加一些数据。然后运行下面的代码。
@Test
public void selectAll() throws Exception {
Connection conn = ConnTools.getConnection();
QueryRunner runner = new QueryRunner();
List<Bean> beans = (List<Bean>) runner.query(conn, "select * from dbutil", new BeanListHandler<Bean>(Bean.class));
DbUtils.close(conn);
for (Bean bean : beans) {
System.out.println(bean.getName());
}
}
结果如下:
MOLLY
Mark1
Mark2
Mark3
Mark4
Mark5
Mark6
Mark7
Mark8
Mark9
Mark10
发现数据库中的所有的数据都被读取过来了。
高级使用
说是高级篇,其实只要是掌握了上面讲的CRUD,就差不多可以正常的进行开发了。这里无非是关于上面的代码的一些看法。
- 首先是单个的Map的数据获取;
@Test
public void map() throws Exception {
Connection conn = ConnTools.getConnection();
QueryRunner runner = new QueryRunner();
java.util.Map<String , Object> map = (java.util.Map<String, Object>) runner.query(conn, "select name from dbutil where id = ?",new MapHandler(),1);
DbUtils.close(conn);
System.out.println(map.get("name"));
}
结果为:
MOLLY
- 然后是多个Map的获取,此时需要借助MapListHandler来实现。
@Test
public void mapList() throws Exception {
Connection conn = ConnTools.getConnection();
QueryRunner runner = new QueryRunner();
List<Map<String,Object>> maps = runner.query(conn, "select * from dbutil",new MapListHandler());
for(Map<String,Object> map : maps) {
System.out.println(map.get("id")+"<<-------->>" + map.get("name"));
}
DbUtils.close(conn);
}
结果是:
1<<-------->>MOLLY
14<<-------->>Mark1
15<<-------->>Mark2
16<<-------->>Mark3
17<<-------->>Mark4
18<<-------->>Mark5
19<<-------->>Mark6
20<<-------->>Mark7
21<<-------->>Mark8
22<<-------->>Mark9
23<<-------->>Mark10
# 主键id的变化是由于采用了自增长策略所引起的,这很正常!
我的理解
关于List型数据,我们需要指定的就是Bean的类型。
其实这一点我们认真的思考一下,也可以想到这是理所当然的嘛。因为在数据库中每一行数据,都是我们的一个Bean的准实例化对象。我们在获取的时候就知道了我们将会获得的数据类型,所以我们需要明确的指定Bean的类型。
指定的时候可以根据传入的参数的不同来决定使用- BeanHandler
- BeanListHandler
关于Map类型的数据,我们唯一需要注意的就是获取到的数据的个数,然后决定使用哪一个处理器,然后对返回的数据集进行逻辑上的处理即可!
- MapHandler
- MaoListHandler
总结
从上面的例子中我们可以看出,在使用DbUtils的过程中,就和使用jdbc的方式是一样的,唯一的不同就是DbUtils的封装性更强了。我们可以方便的从中获取数据。
然后就是对于Map和List方式的数据获取,要使用特定的重载方法和相关的处理器,这样我们才能就事论事的获得我们想要的数据!
本质上来讲,代码只是我们思维的具现化的产物,也是逻辑的物理表现。如果心中根本没有逻辑,又怎么能奢求写出很好的代码。编程永远不仅仅是码代码,更是一种思想。
Apache DbUtils 探秘的更多相关文章
- Apache—DBUtils框架简介
转载自:http://blog.csdn.net/fengdongkun/article/details/8236216 Apache—DBUtils框架简介.DbUtils类.QueryRunner ...
- JDBC 学习笔记(四)—— 自定义JDBC框架+Apache—DBUtils框架+事务管理+操作多表
本文目录: 1.自定义JDBC框架 ——数据库元数据:DataBaseMetaData 2.自定义JDBC框架 ——数据库元数据:DataBaseMetaData ...
- apache DBUtils 使用例子demo
转自:http://blog.csdn.net/earbao/article/details/44901061 apache DBUtils是java编程中的数据库操作实用工具,小巧简单实用, 1.对 ...
- Apache DBUtils使用总结 【转】
Apache DBUtils使用总结 DBUtils是个小巧的JDBC轻量级封装的工具包,其最核心的特性是结果集的封装,可以直接将查询出来的结果集封装成JavaBean,这就为我们做了最枯燥乏味. ...
- Apache—dbutils开源JDBC工具类库简介
Apache—dbutils开源JDBC工具类库简介 一.前言 commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,学习成本极低,并且使用 ...
- Apache—DBUtils框架
1.所需要jar包 commons-collections-2.1.1.jarmchange-commons-java-0.2.11.jarmysql-connector-java-5.1.18-bi ...
- Apache—DBUtils
简介 commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,学习成本极低,并且使用dbutils能极大简化jdbc编码的工作量,同时也不会影 ...
- Apache DbUtils - JDBC轻量级封装的工具包
前段时间使用了Apache Common DbUtils这个工具,在此留个印,以备不时查看.大家都知道现在市面上的数据库访问层的框架很多,当然很多都是包含了OR-Mapping工作步骤的例如大家常用的 ...
- Apache DBUtils框架 结果处理器
package com.itheima.dbutil; import java.util.List; import java.util.Map; import org.apache.commons.d ...
随机推荐
- [Codeforces 961G]Partitions
Description 题库链接 给你 \(n\) 个不同的元素组成的集合 \(R\) ,每个元素有一个权值 \(w\) .对于一个子集集合 \(S\) ,它的价值为 \(W(S)=|S|\cdot\ ...
- [SDOI 2012]Longge的问题
Description Longge的数学成绩非常好,并且他非常乐于挑战高难度的数学问题.现在问题来了:给定一个整数N,你需要求出∑gcd(i, N)(1<=i <=N). Input 一 ...
- [Luogu 3919]【模板】可持久化数组(可持久化线段树/平衡树)
Description 如题,你需要维护这样的一个长度为 N 的数组,支持如下几种操作 在某个历史版本上修改某一个位置上的值 访问某个历史版本上的某一位置的值 此外,每进行一次操作(对于操作2,即为生 ...
- [SCOI2009]windy数
题目描述 windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道, 在A和B之间,包括A和B,总共有多少个windy数? 输入输出格式 输 ...
- NOIP 2007树网的核
题目描述 设T=(V, E, W) 是一个无圈且连通的无向图(也称为无根树),每条边到有正整数的权,我们称T为树网(treebetwork),其中V,E分别表示结点与边的集合,W表示各边长度的集合,并 ...
- bzoj 5297: [Cqoi2018]社交网络
Description 当今社会,在社交网络上看朋友的消息已经成为许多人生活的一部分.通常,一个用户在社交网络上发布一条消息 (例如微博.状态.Tweet等)后,他的好友们也可以看见这条消息,并可能转 ...
- hihiocoder 1255(搜索)(2015ACM/ICPC北京站)
题意: 给你四个矩形,判断能否从中选出3个组成一个矩形 思路: 1.搜索,如果两个能组成一个新的,则将他们合并,继续搜索 2.暴力判断 最开始没注意到3,一直以为要用4个,WR #include &l ...
- bzoj3622已经没有什么好害怕的了 dp+组合+容斥(?)
3622: 已经没有什么好害怕的了 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1033 Solved: 480[Submit][Status][ ...
- ORACLE 触发器 基础
--触发器--语法 CREATE OR REPLACE TRIGGER TRIGGER_NAME AFTER|BEFORE|INSTEAD OF [INSERT][OR UPDATE [OF COLU ...
- 48. Rotate Image(中等)
You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockwise). ...