一、O-R Mapping 简介
    一】概念:可以理解为对象和数据库的映射。
    二】常用O-R Mapping映射工具
        1)Hibernate(全自动框架)
        2)lbatis(半自动框架)
        3)Commons Dbutils(只是对JDBC的简单封装)

二、DBUtils框架(核心类:QueryRunner)

一】QueryRunner类
        1》构造参数:
            public QueryRunner();
            public QueryRunner(DataSource dataSource);        
       
          2》update方法
            1)无Connection参数(对应非空参构造):
                int update(String sql, Object[] objs);
                
                注意:内部已经关闭了连接数据库的流对象,不需要进行手动关闭(查看源码)
              code:

             QueryRunner qr = new QueryRunner(C3P0Utils.getDataSource());
String sql = " INSERT INTO meta.user(username,salary) VALUES(?, ?) ";
qr.update(sql, new Object[]{"jack", 9700.5});
sql = " UPDATE meta.user SET salary = ? WHERE username = ?";
qr.update(sql, new Object[]{10000, "merry"});
sql = " DELETE FROM meta.user WHERE username = ? ";
qr.update(sql, new Object[]{"xixi"});

2)有Connection参数(对应空参构造):
                int update(Connection conn, String sql, Object[] objs);
                
                注意:内部除Connection外的对象已经自动关闭,但Connection并没有自动关闭,
                      故,需要手动关闭Connection对象。
              code:

                QueryRunner qr = new QueryRunner();
QueryRunner qr = new QueryRunner();
Connection conn = C3P0Utils.getMySqlConnection();
String sql = " INSERT INTO meta.user(username, salary) VALUES(?, ?) ";
qr.update(conn, sql, new Object[]{"hehe", 7000.3});

3》query()方法
            1)同样有带有参数Connection和不带有参数Connnection两种
            2)需要ResultSetHandler接口的实现类配合使用。

三】ResultSetHandler接口
        实现类:
            1)BeanHeadler/BeanListHandler:针对Bean
                    BeanHeadler:将查询结果的第一行结果封装成一个Bean对象
                    BeanListHandler:将所有行的查询结果封装成多个Bean对象,并将Bean对象存入List中

2)ArrayHandler/ArrayListHandler:针对数组
                    ArrayHandler:将查询结果的第一行结果添加到一个数组中
                    ArrayListHandler:将所有行的查询结果添加到多个数组中,并将数组存入List中

3)MapHandler/MapListHandler:针对Map
                    MapHandler:将查询结果的第一行结果,按照 <每列字段,每列结果> 的方式放入Map集合中
                    MapListHandler:将查询结果的多行结果,按照 <每列字段,每列结果> 的方式放入多个Map集合中,并将这些Map集合放入List中

4)ScalarHandler:针对Long
                    将查询结果的 第一行,第一列 的数据返回。

code:

         QueryRunner qr = new QueryRunner(C3P0Utils.getDataSource());
String sql = " SELECT * FROM meta.user "; //BeanHandler:
User user = (User) qr.query(sql, new BeanHandler(User.class));//1 : merry : 10000.0
System.out.println(user); //BeanListHandler:
List<User> list = (List<User>) qr.query(sql, new BeanListHandler(User.class));
for (User u : list) {
System.out.println(u);
}
/*1 : merry : 10000.0
1 : merry : 10000.0
2 : berry : 10000.0
3 : hehe : 7000.3*/ //ArrayHandler
Object[] info = (Object[]) qr.query(sql, new ArrayHandler());
for (int i = 0; i < info.length; i++) {
System.out.println(info[i]);//1 merry 10000.0
} //ArrayListHandler
List<Object[]> list = (List<Object[]>) qr.query(sql, new ArrayListHandler());
for (Object[] obj : list) {
for (int i = 0; i < obj.length; i++) {
System.out.print(obj[i] + " : ");
}
System.out.println();
}
/*
1 : merry : 10000.0 :
2 : berry : 10000.0 :
3 : hehe : 7000.3 : */ //MapHandler
Map<String, Object> map = (Map<String, Object>) qr.query(sql, new MapHandler());
int id = (int) map.get("id");
String username = (String) map.get("username");
double salary = (double) map.get("salary");
System.out.println(id + " : " + username + " : " + salary);//1 : merry : 10000.0 //MapListHandler
List<Map<String, Object>> list = (List<Map<String, Object>>) qr.query(sql, new MapListHandler());
for (Map<String, Object> map : list) {
int id = (int) map.get("id");
String username = (String) map.get("username");
double salary = (double) map.get("salary");
System.out.println(id + " : " + username + " : " + salary);
}
/*1 : merry : 10000.0
2 : berry : 10000.0
3 : hehe : 7000.3*/ //ScalarHandler
String sca_sql = " SELECT COUNT(*) FROM meta.user ";
long cnt = (long) qr.query(sca_sql, new ScalarHandler());
System.out.println(cnt);//

三、应用

1)一对多/多对一 关系中: (部门与员工)

          QueryRunner qr = new QueryRunner(C3P0Utils.getDataSource());
//1,将部门插入表department中
String INSERT_DEPARTMENT = " INSERT INTO dbutils.department(name) VALUES(?) ";
qr.update(INSERT_DEPARTMENT, de.getName());
//2,获取部门的主键,可用于表employee表的外键
String DEPART_PRIMARY_KEY = " SELECT id FROM dbutils.department WHERE name = ? ";
int did = (int) qr.query(DEPART_PRIMARY_KEY, de.getName(), new ScalarHandler());
//3,将员工信息插入表employee中,并与表department产生关联关系
String INSERT_EMPLOYEE = " INSERT INTO dbutils.employee(name, did) VALUES(?, ?) ";
List<Employee> list = de.getList();
for (Employee e : list) {
qr.update(INSERT_EMPLOYEE, new Object[]{e.getName(), did});
}

2)多对多 关系中: (学生与老师)

         QueryRunner qr = new QueryRunner(C3P0Utils.getDataSource());
//1,插入教师信息到teacher表中
String ADD_TEA_INFO = " INSERT INTO dbutils.teacher(name) values(?) ";
qr.update(ADD_TEA_INFO, tea1.getName());
//2,获取插入的教师的id
String QUERY_TEA_ID = " SELECT id FROM dbutils.teacher WHERE name = ? ";
int tid = (int) qr.query(QUERY_TEA_ID, tea1.getName(), new ScalarHandler()); //3,插入学生信息到表student中
String ADD_STU_INFO = " INSERT INTO dbutils.student(name) VALUES(?) ";
List<Student> stus = tea1.getStus();
for (Student stu : stus) {
qr.update(ADD_STU_INFO, stu.getName());
} //4,获取所有学生id
String ALL_STU_ID = " SELECT id FROM dbutils.student ";
List<Object[]> list = (List<Object[]>) qr.query(ALL_STU_ID, new ArrayListHandler());
//5,将学生id和老师id对应插入到表middle中,建立相互联系
String BUILD_REALATION = " INSERT INTO dbutils.middle(sid, tid) VALUES(?, ?) ";
for ( Object[] sids : list) {
qr.update(BUILD_REALATION, new Object[]{sids[0], tid});
}

    注意:数据库的多表查询会话费很多时间,所以有时候允许数据的冗余,以空间换取时间。

DBUtils框架的更多相关文章

  1. Apache—DBUtils框架简介

    转载自:http://blog.csdn.net/fengdongkun/article/details/8236216 Apache—DBUtils框架简介.DbUtils类.QueryRunner ...

  2. JDBC 学习笔记(四)—— 自定义JDBC框架+Apache—DBUtils框架+事务管理+操作多表

    本文目录:       1.自定义JDBC框架 ——数据库元数据:DataBaseMetaData        2.自定义JDBC框架 ——数据库元数据:DataBaseMetaData       ...

  3. JNDI和在tomcat中配置DBCP连接池 元数据的使用 DBUtils框架的使用 多表操作

    1 JNDI和在tomcat中配置DBCP连接池 JNDI(Java Naming and Directory Interface),Java命名和目录接口,它对应于J2SE中的javax.namin ...

  4. javaweb学习总结(四十一)——Apache的DBUtils框架学习

    一.commons-dbutils简介 commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,学习成本极低,并且使用dbutils能极大简化 ...

  5. Java Web(十) JDBC的增删改查,C3P0等连接池,dbutils框架的使用

    前面做了一个非常垃圾的小demo,真的无法直面它,菜的抠脚啊,真的菜,好好努力把.菜鸡. --WH 一.JDBC是什么? Java Data Base Connectivity,java数据库连接,在 ...

  6. JavaWeb 后端 <十一> 之 DBUtils 框架 (基本使用 结果集 事务处理 对表读取)

    一.数据库操作框架 1.ORM:Object Relation Mapping Hibernate:非常流行 JPA:Java Persistent API.ORM标准 MyBatis:2010年开始 ...

  7. JDBC第四篇--【数据库连接池、DbUtils框架、分页】

    1.数据库连接池 什么是数据库连接池 简单来说:数据库连接池就是提供连接的. 为什么我们要使用数据库连接池 数据库的连接的建立和关闭是非常消耗资源的 频繁地打开.关闭连接造成系统性能低下 编写连接池 ...

  8. JDBC【数据库连接池、DbUtils框架、分页】

    1.数据库连接池 什么是数据库连接池 简单来说:数据库连接池就是提供连接的... 为什么我们要使用数据库连接池 数据库的连接的建立和关闭是非常消耗资源的 频繁地打开.关闭连接造成系统性能低下 编写连接 ...

  9. 开源框架:Apache的DBUtils框架

    开源框架:Apache的DBUtils框架 Commons DbUtils 1.4 API 开源框架:DBUtils使用详解 Download Apache Commons DbUtils  官方文档

随机推荐

  1. SublimeText的使用

    1.安装Sublime_text2.02文件:Sublime Text 2.0.2.tar.bz2 (1)官网下载地址:http://www.sublimetext.com/2 (2)将文件放到lin ...

  2. 执行测试遇到log4j 没有找到日志appenders

    log4j:WARN No appenders could be found for logger (com.sshtools.j2ssh.transport.publickey.SshKeyPair ...

  3. 自然数e这家伙怎么蹦跶出来的?

    自然数e这家伙怎么蹦跶出来的? 之前看过一篇中文介绍自然数e的blog,引起了我的兴趣 原文是阮一峰大牛(我认为必须很有必要尊敬的称,大牛)嚼烂了吐出来的哈哈,只是我认为还是自己去看原文比較好 感觉非 ...

  4. ndroid网络(4):HttpClient必经之路----使用线程安全的单例模式HttpClient,及HttpClient和Application的融合

    上文简 单介绍了HttpClient和Tomcat服务器的交互,主角是HttpClient,然后它跟服务器交互有两种方式即get和post.所以这个 HttpClient就类似于电脑上用的浏览器.当我 ...

  5. LINUX更改时区和时间

    因为公司运营海外游戏,服务器也多数放在国外,有时候要求服务器时区和时间要与所服务的地区一致,这里就涉及到更改服务器时区和时间的问题: 下面以一台在美国的服务器为例,我们的IDC提供商是一家德国公司,服 ...

  6. 关于lower_bound()的用法--NYOJ 201作业题

    lower_bound它有三个参数, 第一个和第二个是给定区间起点和终点的指针,第三个参数是要查找的数,它的作用原理是在给定的区间中进行二分查找,这个二分区间是前开后闭的,他返回第一个大于等于它的函数 ...

  7. Windows下将硬盘由MBR转为GPT

    打开命令提示符,输入 diskpart 进入diskpart提示符.Win7/Vista用户可以直接在开始菜单的搜索框中输入diskpart回车即可打开diskpart提示符. 在diskpart提示 ...

  8. 4、第4次课 CSS代码第三节课20150923

    1.列表li样式及取值意义 list-style-type : disc | circle | square | decimal | lower-roman | upper-roman | lower ...

  9. boostrap按钮

    bootstrap按钮 对应链接:http://v3.bootcss.com/css/#buttons 使用时添加基础类class:btn 默认样式class=btn-default,控制大小clas ...

  10. 3.RxJava详解

    一.RxJava 到底是什么 异步(取代AsyncTask/Handler/XXX/...?)   二.RxJava 好在哪   简洁(逻辑的简洁,.一步一走)   举例: 题目:将文件夹中的图片都取 ...