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

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

Hibernate3的DetachedCriteria支持

2019-11-18 15:40:59
字體:
來源:轉載
供稿:網友
  Hibernate3支持DetachedCriteria,這是一個非常有意義的特性!我們知道,在常規的Web編程中,有大量的動態條件查詢,即用戶在網頁上面自由選擇某些條件,程序根據用戶的選擇條件,動態生成SQL語句,進行查詢。

  針對這種需求,對于分層應用程序來說,Web層需要傳遞一個查詢的條件列表給業務層對象,業務層對象獲得這個條件列表之后,然后依次取出條件,構造查詢語句。這里的一個難點是條件列表用什么來構造?傳統上使用Map,但是這種方式缺陷很大,Map可以傳遞的信息非常有限,只能傳遞name和value,無法傳遞究竟要做怎樣的條件運算,究竟是大于,小于,like,還是其它的什么,業務層對象必須確切把握每條entry的隱含條件。因此一旦隱含條件改變,業務層對象的查詢構造算法必須相應修改,但是這種查詢條件的改變是隱式約定的,而不是程序代碼約束的,因此非常輕易出錯。

  DetachedCriteria可以解決這個問題,即在web層,程序員使用DetachedCriteria來構造查詢條件,然后將這個DetachedCriteria作為方法調用參數傳遞給業務層對象。而業務層對象獲得DetachedCriteria之后,可以在session范圍內直接構造Criteria,進行查詢。就此,查詢語句的構造完全被搬離到web層實現,而業務層則只負責完成持久化和查詢的封裝即可,與查詢條件構造完全解耦,非常完美!這恐怕也是以前很多企圖在web層代碼中構造HQL語句的人想實現的夢想吧!

  示例代碼片段如下:

  web層程序構造查詢條件:

  java代碼:

DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Department.class);
detachedCriteria.add(Restrictions.eq("name", "department")).createAlias("employees", "e").add(Restrictions.gt(("e.age"), new Integer(20)));
  Department和Employee是一對多關聯,查詢條件為:

  名稱是“department”開發部門;
  部門里面的雇員年齡大于20歲;

  業務層對象使用該條件執行查詢:

  java代碼:

detachedCriteria.getExecutableCriteria(session).list();
  最大的意義在于,業務層代碼是固定不變的,所有查詢條件的構造都在web層完成,業務層只負責在session內執行之。這樣代碼就可放之四海而皆準,都無須修改了。

  然而SPRing和Hibernate3的DetachedCriteria有不兼容的問題,因此在Spring環境下面使用Hibernate3需要注重:

  Spring的HibernateTemplate提供了Hibernate的完美封裝,即通過匿名類實現回調,來保證Session的自動資源治理和事務的治理。其中核心方法是:

  java代碼:

HibernateTemplate.execute(new HibernateCallback() {
 public Object doInHibernate(Session session) throws HibernateException {
  ....
 }
}
  回調方法提供了session作為參數,有了session,就可以自由的使用Hibernate API編程了。使用了spring的之后,代碼修改如下:

  web層代碼:

  java代碼:

DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Department.class);
detachedCriteria.createAlias("employees", "e").add(Restrictions.eq("name", "department")).add(Restrictions.gt(("e.age"), new Integer(20)));
departmentManager.findByCriteria(detachedCriteria);
  構造detachedCriteria,作為參數傳遞給departmentManager

  業務層代碼使用spring,DepartmentManager的findByCriteria如下:

  java代碼:

public List findByCriteria(final DetachedCriteria detachedCriteria) {
 return (List) getHibernateTemplate().execute(new HibernateCallback() {
  public Object doInHibernate(Session session) throws HibernateException {
   Criteria criteria = detachedCriteria.getExecutableCriteria(session);
   return criteria.list();
  }
 });
}
  實際上也就是:

  java代碼:



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 麻城市| 辉县市| 合川市| 上犹县| 西和县| 皋兰县| 镇原县| 阳东县| 柳河县| 赤水市| 敦化市| 灵川县| 类乌齐县| 洪泽县| 四子王旗| 濮阳县| 三门峡市| 禹州市| 九台市| 朔州市| 郑州市| 丹江口市| 虹口区| 镇坪县| 东山县| 凌云县| 玛沁县| 准格尔旗| 桐庐县| 朝阳市| 丹巴县| 谢通门县| 台东市| 察雅县| 鄂托克前旗| 莱西市| 教育| 兴业县| 普洱| 金湖县| 天等县|