设为首页 收藏本站
查看: 681|回复: 0

[经验分享] Apache ---- DBUilts框架源码

[复制链接]

尚未签到

发表于 2017-1-2 10:13:47 | 显示全部楼层 |阅读模式
  Apache ---- DBUilts框架源码
  一 简介
  Commons-dbutils是Apache组织提供了一个开源jdbc工具类库,它是读jsbc’的简单封装,学习成本极低,并且使用dbutils能极大的简化jdbc编码的工作量同时也不会影响程序的性能
  API的介绍
  Org.apache.connons.dbutils.QueryRunneer ---相当于DBManager
  Org.apache.connons.dbutils.ResultSetHandler
  工具类:
  Org.apache.connons.dbutils.DbUtils
  二 类和接口的介绍
  1.DbUtils类的介绍
  (1)dbUtils提供了如关闭连接,装在jdbc驱动程序等常规工作的工具类,里面的方法都是静态的。
  (2)public static void close(…) throws java.sql.SQLException: DbUtils类提供了三个重载的关闭方法。这些方法检查所提供的参数是不是NULL,如果 不是的话,它们就关闭Connection、Statement和ResultSet。
  (3)public static void closeQuietly(…): 这一类方法不仅能在Connection、Statement和ResultSet为NULL情况下避免关闭,还能隐藏一些在程序中抛出的SQLEeception。
  (4)public static void commitAndCloseQuietly(Connection conn): 用来提交连接,然后关闭连接,并且在关闭连接时不抛出SQL异常。
  (5)public static boolean loadDriver(java.lang.
  String driverClassName):这一方装载并注册JDBC驱动程序,如果成功就返回true。使用该方法,你不需要捕捉这个异常ClassNotFoundException。
  2.QueryRunner类 --- 核心类
  (1)该类简单化了SQL查询,它与ResultSetHandler组合在一起使用可以完成大部分的数据库操作,能够大大减少编码量。
  (2)QueryRunner类提供了两个构造方法:
  · 默认的构造方法
  · 需要一个 javax.sql.DataSource 来作参数的构造方法。
  3.ResultSetHandler接口
  (1)该接口用于处理 java.sql.ResultSet,将数据按要求转换为另一种形式。
  (2)ResultSetHandler 接口提供了一个单独的方法:Object handle (java.sql.ResultSet .rs)。
  4.ResultSetHandler 接口的实现类
  (1)ArrayHandler:把结果集中的第一行数据转成对象数组。
  (2)ArrayListHandler:把结果集中的每一行数据都转成一个数组,再存放到List中。
  (3)BeanHandler:将结果集中的第一行数据封装到一个对应的JavaBean实例中。
  (4)BeanListHandler:将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。
  三 实例应用
  1.创建
  public class UserDaoImpl {
  // 插入操作
  public void insert() {
  // 得到数据库连接池对象
  QueryRunner runner = new QueryRunner(DBManager_c3p0.getDataSource());
  String sql = "insert into users(name,password) values('liop','8988')";
  try {
  runner.update(sql);
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }
  }
  // 删除操作
  public void delete() {
  QueryRunner runner = new QueryRunner(DBManager_c3p0.getDataSource());
  String sql = "delete from users where id=1";
  try {
  runner.update(sql);
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }
  }
  // 更新操作
  public void update() {
  QueryRunner runner = new QueryRunner(DBManager_c3p0.getDataSource());
  String sql = "update users set name='老王',password=222 where id=3";
  try {
  runner.update(sql);
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }
  }
  // 通过Id查询操作
  public void findById() {
  QueryRunner runner = new QueryRunner(DBManager_c3p0.getDataSource());
  String sql = "select * from users where id=3";
  BeanHandler rsh = new BeanHandler(User.class);
  try {
  User user = runner.query(sql, rsh);
  System.out.println(user.toString());
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }
  }
  // 查询所有
  public void findAll() {
  QueryRunner runner = new QueryRunner(DBManager_c3p0.getDataSource());
  String sql = "select * from users";
  BeanListHandler rsh = new BeanListHandler(User.class);
  try {
  List<User> entities = runner.query(sql, rsh);
  System.out.println(entities.size());
  for (User entity : entities) {
  System.out.println(entity.toString());
  }
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }
  }
  // 批处理
  public void bath() {
  QueryRunner runner = new QueryRunner(DBManager_c3p0.getDataSource());
  String sql = "insert into users(name,password) values(?,?)";
  Object[][] params = { { "老李", "111" }, { "qqq", "222" },
  { "www", "333" }, { "eee", "444" } };
  try {
  runner.batch(sql, params);
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }
  }
  // ArrayHandler的使用
  public void testArrayHandler() {
  QueryRunner runner = new QueryRunner(DBManager_c3p0.getDataSource());
  String sql = "select * from users where id=5";
  ArrayHandler rsh = new ArrayHandler();
  try {
  Object[] array = runner.query(sql, rsh);
  System.out.println(Arrays.asList(array));
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }
  }
  // ArrayListHandler的使用
  public void testArrayListHandler() {
  QueryRunner runner = new QueryRunner(DBManager_c3p0.getDataSource());
  String sql = "select * from users";
  ArrayListHandler rsh = new ArrayListHandler();
  try {
  List<Object[]> array = runner.query(sql, rsh);
  for (int i = 1; i < array.size(); i++) {
  System.out.println(Arrays.asList(array.get(i)));
  }
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }
  }
  2.测试
  public static void main(String[] args) {
  new UserDaoImpl().insert();
  new UserDaoImpl().delete();
  new UserDaoImpl().update();
  new UserDaoImpl().findById();
  new UserDaoImpl().findAll();
  // 批处理
  new UserDaoImpl().bath();
  // 数组使用
  new UserDaoImpl().testArrayHandler();
  //数组
  //new UserDaoImpl().testArrayListHandler();
  }

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-322744-1-1.html 上篇帖子: Apache Ant 快速参考手册 下篇帖子: apache的mod_rewrite总结
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表