bboss 持久层框架使用最佳实践-带连接(connection)参数接口和不带连接参数接口的选择

简介: bboss 持久层框架使用最佳实践-带连接(connection)参数接口和不带连接参数接口的选择bboss项目下载列表 在sourceforge访问地址为:https://sourceforge.net/project/showfiles.php?group_id=238653  bboss 持久层框架提供了两类访问数据库的接口:带connection参数的接口和不带connection参数的接口。

bboss 持久层框架使用最佳实践-带连接(connection)参数接口和不带连接参数接口的选择

bboss项目下载列表 在sourceforge访问地址为:
https://sourceforge.net/project/showfiles.php?group_id=238653

 

bboss 持久层框架提供了两类访问数据库的接口:带connection参数的接口和不带connection参数的接口。这两类接口在各种场合下面都可以使用,实现的功能都是一样的,但是适用的场合还是不一样的,下面分别描述。

 

  1. 带连接connection参数的接口

带连接connection参数的接口在访问数据库时不再向bboss数据库连接池申请连接而直接使用外部参数传入的connection,这样一个connection可以供多个数据库操作使用,适用于数据库操作比较密集的环境,这样能够大大地提升应用程序的性能;如果在这种情况下使用不带connection参数的接口,意味着每次访问数据库都要向bboss连接池申请connection,由于连接池是一种串行化的带并发锁定的组件,频繁的申请和释放将导致严重的系统性能开销,最终导致系统性能缓慢。使用带connection参数的方法时需要确保最后关闭connection,防止连接泄漏。使用的步骤如下:

   a.调用DBUtil.getConnection()或者DBUtil.getConnection(String dbname)方法申请一个数据库连接

   b.访问DBUtil或者PreparedDBUtil或者CallableDBUtil的带connection参数的方法传入刚申请的connection对象进行数据库操作

   c.操作完毕后在finally块中关闭连接

 

这里以预编译操作接口(其他接口都提供了类似功能不一一枚举)为例,举例如下:

 

PreparedDBUtil db = new PreparedDBUtil();
  Connection con = null;
  try {
   con = DBUtil.getConection(); //申请连接
   db.preparedDelete("delete from test");
   db.executePrepared(con);//使用连接
   
   db.preparedInsert("insert into test(id,name) values(?,?)");
   db.setString(1, "1");
   db.setString(2, "name");
   db.executePrepared(con);//使用连接
   
   db.preparedInsert("insert into test(name) values(?)");

   db.setString(1, "name");
   db.executePrepared(con);//使用连接
   
   db.preparedInsert("insert into test(name,clobname,blobname) values(?,?,?)");

   db.setString(1, "name");
   db.setClob(2, "content");
   db.setBlob(3, "content".getBytes());
   db.executePrepared(con);//使用连接
   
   db.preparedSelect("select * from test where name=?");
   //db.setString(1, "1");
   db.setString(1, "name");
   db.executePrepared(con);//使用连接
   
   
   for(int i = 0; i < db.size(); i ++)
   {
    System.out.println(i + " id=" + db.getString(i, "id"));
    System.out.println(i + " name=" + db.getString(i, "name"));
    
   }
   
  } catch (Exception e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  finally
  {
   try {

   if(con != null)
        con.close();//关闭连接
   } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }

 

 

 

2.不带连接参数的接口

 

不带connection参数的方法适用于以下场景:

    单一的数据库操作环境

    事务环境中的数据库操作接口

 

下面举例说明:

 

  • 单一的数据库操作

 

PreparedDBUtil db = new PreparedDBUtil();
    try {
     db.preparedDelete("delete from test");
     db.executePrepared();//使用不带连接的方法


} catch (Exception e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }

  • 事务环境下的多次数据库操作

PreparedDBUtil db = new PreparedDBUtil();
  TransactionManager tm = new TransactionManager();
  try {
   tm.begin();
   db.preparedDelete("delete from test");
   db.executePrepared();
   
   db.preparedInsert("insert into test(id,name) values(?,?)");
   db.setString(1, "test1");
   db.setString(2, "name");
   db.executePrepared();
   
   db.preparedInsert("insert into test(name) values(?)");

   db.setString(1, "name auto id");
   db.executePrepared();
   
   db.preparedInsert("insert into test(name,clobname,blobname) values(?,?,?)");

   db.setString(1, "name with clob and blob");
   db.setClob(2, "content");
   db.setBlob(3, "content".getBytes());
   db.executePrepared();
   
   db.preparedSelect("select * from test where name=?");
   //db.setString(1, "1");
   db.setString(1, "name");
   db.executePrepared();
   
   
   for(int i = 0; i < db.size(); i ++)
   {
    System.out.println(i + " id=" + db.getString(i, "id"));
    System.out.println(i + " name=" + db.getString(i, "name"));
    
   }
   tm.commit();
  } catch (Exception e) {
   try {
    tm.rollback();
   } catch (RollbackException e1) {
    // TODO Auto-generated catch block
    e1.printStackTrace();
   }
  }

目录
相关文章
|
8月前
|
SQL Java 数据库连接
Mybatis之核心配置文件详解、默认类型别名、Mybatis获取参数值的两种方式
【1月更文挑战第3天】 一、核心配置文件详解 二、默认的类型别名 三、MyBatis的增删改查 四、MyBatis获取参数值的两种方式 1、单个字面量类型的参数 2、多个字面量类型的参数 3、map集合类型的参数 4、实体类类型的参数 5、使用@Param标识参数
155 2
Mybatis之核心配置文件详解、默认类型别名、Mybatis获取参数值的两种方式
【干货】sql-labs、请求方式、注入类型、拼接方式
【干货】sql-labs、请求方式、注入类型、拼接方式
|
5月前
|
SQL Java 数据库连接
JDBC连接SQL Server2008 完成增加、删除、查询、修改等基本信息基本格式及示例代码
这篇文章提供了使用JDBC连接SQL Server 2008数据库进行增加、删除、查询和修改操作的基本步骤和示例代码。
|
6月前
|
Java 数据库连接 mybatis
Mybatis查询传递单个参数和传递多个参数用法
Mybatis查询传递单个参数和传递多个参数用法
88 11
|
存储 Oracle Java
[亲测可用]hibernate调用Oracle存储过程|Spring Data JPA调用Oracle存储过程方法
[亲测可用]hibernate调用Oracle存储过程|Spring Data JPA调用Oracle存储过程方法
|
SQL 程序员 数据库
789.【技术】当可选http接口和sql造数据,你会选用哪种方式呢?
789.【技术】当可选http接口和sql造数据,你会选用哪种方式呢?
159 0
|
JSON NoSQL Go
GoFrame gredis 硬核解析 | DoVar、Conn连接对象、自动序列化
详细的介绍了gredis的使用,包括:Do/DoVar方法的使用及区别、复杂场景下使用Conn方法从连接池中获取一个redis连接对象、当给定的参数为map, slice, struct时,gredis内部支持自动对其使用json序列化,并且读取数据时可使用gvar.Var的转换功能实现反序列化。
243 0
GoFrame gredis 硬核解析 | DoVar、Conn连接对象、自动序列化
|
SQL Oracle 关系型数据库
JDBC(四) 连接参数的配置(附DBUtil工具类)
进行JDBC操作时,连接参数的配置(附DBUtil工具类)
JDBC(四)  连接参数的配置(附DBUtil工具类)
|
SQL Java 数据库连接
mybatis学习(11): sql server配置管理器请求失败或服务未及时响应
mybatis学习(11): sql server配置管理器请求失败或服务未及时响应
599 0
mybatis学习(11): sql server配置管理器请求失败或服务未及时响应
|
JSON Java 数据格式
SpringMVC中请求参数的绑定【绑定机制、支持的数据类型、使用要求、乱码解决】(超详细)
SpringMVC中请求参数的绑定【绑定机制、支持的数据类型、使用要求、乱码解决】(超详细)
SpringMVC中请求参数的绑定【绑定机制、支持的数据类型、使用要求、乱码解决】(超详细)