国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

探討JDBC 4.0在設計和性能方面的改進

2019-11-18 13:34:06
字體:
來源:轉載
供稿:網友
摘要 JDBC(java數據庫連接)4.0預計在2006年中期作為Java 6.0標準版的一部分正式發行。現在,我們大家都關心的問題是,如何利用這一新的規范來改進Java應用程序數據存取和交互方面的設計與性能。本文將與你一起探討JDBC 4.0中引入的新特征,討論它對一些現有問題的解決方案,并且通過具體示例展示它在設計和性能方面的改進。

  自從核心Java語言的第一個公開發行版本起,JDBC(Java數據庫連接)已經經歷了十年的發展歷程。它的當前版本4.0(將與Java標準版本6.0一起打包發行)提供了一組更為豐富的API,主要目的在于改進軟件開發的設計和性能。

  本文將重點討論JDBC 4.0規范在設計和性能方面的改進。

  一、 注釋和泛型DataSet

  在本文中,我假定你已經了解注釋和泛型。其實,這兩個概念是隨著J2SE 5.0的發行一同引入的;與此同時,JDBC 4.0中引入了注釋和泛型DataSet。這一變化的主要目的是為了簡化SQL查詢和SQL DML(數據操縱語言)語句的執行。

  新一代API定義了一組Query和DataSet接口。這個Query接口定義了一組帶有JDBC注釋的方法。這些帶有注釋的方法描述了SQL select和update語句,并且指定應該如何把結果綁定到一個DataSet上。這個DataSet接口是一個通過泛型定義實現的參數化類型,也為結果集數據提供一種類型安全的定義。

  所有的Query接口都繼續自BaseQuery接口。你可以使用Connection.createQueryObject()或DataSource.createQueryObject()方法(這兩個方法都使用一個Query接口類型作為它的參數)來具體實現這樣的接口。

  一個DataSet接口繼續自java.util.List;該接口使用一個描述結果集數據列的數據庫(該數據庫是通過Query接口的一個注釋的方法返回的)作為它的參數類型。在連接方式和非連接方式下都可以操作和使用DataSet。因此,根據使用的是連接方式還是非連接方式,這個DataSet也分別相應地實現為一個ResultSet或CachedRowSet。DataSet,作為java.util.List的一個子接口,答應使用Iterator模式通過java.util.Iterator接口存取其數據行。

  你可以用兩種方式來指定數據類或用戶定義類(作為DataSet接口的一個參數類型)-作為一個結構或作為一個JavaBeans對象。無論哪一種方式都能夠把結果集數據列綁定到用戶定義的類定義上;但是,JavaBeans組件模型更漂亮些,并且更利于對象定義在另外的支持JavaBeans模型的框架中的重用。

  列表1摘自本文示例中的代碼片斷,它展示了如何使用這種新型的API來創建和運行SQL查詢:使用一個用戶定義類定義結果集數據,并且把返回的結果集綁定到用戶定義的描述中。

  列表1.Employee用戶定義類型與employeeQueries接口

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;
 }
 public String getLastName() {
  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 ();
  二、 改進異常處理能力

  在JDBC API 4.0以前的版本中,異常處理功能極其有限。對于所有類型的錯誤都會籠統地拋出一個SQLException異常-根本不存在異常的具體分類,且沒有相應的層次定義。所以這時,你唯一能夠得到一些有意義的信息的辦法是檢索和分析SQLState值。另一方面,SQLState值及其相應的含義會因不同的數據源而有所改變;因此,要想追蹤到問題的"根部"并且有效地處理異常是一件非常乏味的任務。

  JDBC 4.0改進了異常處理能力,同時也緩解了一些前面提到的問題。其中的要害改進有:

  · 把SQLException分成短暫異常和非短暫異常兩種類型

  · 支持鏈式異常

  · 實現Iterable接口

  當一個以前失敗的操作檢索成功時,將會拋出SQLTransientException異常;而在檢索不成功時將會拋出SQLNonTransientException異常-除非導致SQLException的原因得到糾正。

  圖1展示了子類SQLTransientException和SQLNonTransientException。



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 台北县| 鸡东县| 昌都县| 舞钢市| 晴隆县| 芮城县| 新平| 织金县| 泰宁县| 东乡县| 都安| 嫩江县| 四会市| 固镇县| 宁阳县| 龙游县| 舞钢市| 新巴尔虎左旗| 富锦市| 通辽市| 安塞县| 岑巩县| 固安县| 鹤庆县| 睢宁县| 丰宁| 东至县| 安顺市| 贡觉县| 治多县| 梁山县| 含山县| 枞阳县| 铁力市| 尤溪县| 周至县| 砀山县| 封丘县| 西丰县| 六盘水市| 宜春市|