JDBC4 简介

转载请注明出处:http://www.blogjava.net/nake/
   自从 java 发布的第一个版本开始就已经包含 JDBC 了。目前已经有 10 个年头了。 JDBC4.0将要被打包到 java6.0 里( java SE 是 J2SE 新的名字)。它展现设计的重大提升和提供更加丰富的 API ,更加重视简易开发和提高生产力 。

       本文将讨论一些 JDBC 在改善设计和提高性能上的重要的变化。但是不能列举每一个变化。

注解和泛型

我想你已经了解了包含在 JAVA 5.0 的注解( annotations ) 和泛型( generic 也有翻译范型)。 JDBC4.0 也引进了注解和泛型 DataSet ,这使得执行 sql 语句和 SQL  DML ( data manipulation  language ) 定义变的简单。

       在新的 API 里定义了一套 Query 和 DataSet 接口。 Query 接口定义了一套方法,这些方法描述了 SQL 的 select 和 update 语句。而且详细介绍了结果集如何绑定为一个 DataSet 的。因为泛型所以 DataSet 是可以带参数的。因此可以说 DataSet 接口是类型安全的( type-saft ).

所有 Query 接口都要从 BaseQuery 接口继承。可以通过 Connection.createQueryObject() 或者 DataSource.createQueryObject() 得到Query对象。

一个DataSet接口都继承java.util.List。   DataSet 是有列概念的数据集,能从 Query 接口得到,并且可以带有参数。 DataSet 可以在连接和断开连接的情况下使用。从而 DataSet实现了 ResultSet (连接) 或者   CachedRowSet (可以断开连接)。因为DataSetjava.util.List的子接口,所以可以通过java.util.Iterator来访问每一行。

DataSet 接口可以带系统或者用户自己定义的类作为参数。通过两种方法你可以实现:构造函数或者 JavaBeans 对象,任何一个办法都能达到将用户自定义的类绑定到结果集的列里。但是在其它支持 JavaBeans 的框架里,用 JavaBeans 对象的实现就显更加容易使用。

下面简单举例说明如何通过新的 API 创建和运行 SQL 查询。用用户自定义的类来定义结果集。(拷贝时候小心有制表符)

pubic class Employee { 
   private int employeeId; 
   private String firstName; 
   private String lastName; 

   public int getEmployeeId() { 
      return employeeId; 
   } 
   
   public setEmployeeId(int employeeId) { 
      this.employeeId = employeeId; 
   } 

   public String getFirstName() { 
      return firstName; 
   } 

   public setFirstName(String firstName) { 
      this.firstName = firstName; 
   } 

   pubic String lastName() { 
      return lastName; 
   } 

   public setLastName(String lastName) { 
      this.lastName = lastName; 
   } 
}

interface EmployeeQueries extends BaseQuery { 
   @Select (sql="SELECT employeeId, firstName, lastName FROM employee") 
   DataSet<Employee> getAllEmployees (); 

   @Update (sql="delete from employee") 
   int deleteAllEmployees (); 
} 


Connection con = ... 

EmployeeQueries empQueries = con.createQueryObject (EmployeeQueries.class); 

DataSet<Employee> empData = empQueries.getAllEmployees ();

 

异常处理的增强:

1.       为 SQLException 分为两类 transient 和 non-transient 。

2.       支持连锁的异常。

3.       继承了 Iterable 接口。

因为继承了Iterable 所以你可以这样写:

catch(SQLException ex) { 
   for(Throwable t : ex) { 
      System.out.println("exception:" + t); 
   } 
}

JDBC4 SQL EXCEPTION

 

 

最后,注:hibernate 3.5已经添加了对JDBC4的支持

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值