自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Hibernate DetachedCriteria學習經(jīng)驗

開發(fā) 后端
這里介紹Hibernate DetachedCriteria,這是一個非常有意義的特性!我們知道,在常規(guī)的Web編程中,有大量的動態(tài)條件查詢,即用戶在網(wǎng)頁上面自由選擇某些條件,程序根據(jù)用戶的選擇條件,動態(tài)生成SQL語句,進行查詢。

本文向大家介紹Hibernate DetachedCriteria,可能好多人還不了解,沒有關系,看完本文你肯定有不少收獲,希望本文能教會你更多東西。

Hibernate DetachedCriteria,這是一個非常有意義的特性!我們知道,在常規(guī)的Web編程中,有大量的動態(tài)條件查詢,即用戶在網(wǎng)頁上面自由選擇某些條件,程序根據(jù)用戶的選擇條件,動態(tài)生成SQL語句,進行查詢。

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

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

示例代碼片段如下:

  1. DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Department.class);  
  2. detachedCriteria.add(Restrictions.eq("name", "department")).
    createAlias("employees", "e").add(Restrictions.gt(("e.age"), new Integer(20))); 

Department和Employee是一對多關聯(lián),查詢條件為:名稱是“department”開發(fā)部門;部門里面的雇員年齡大于20歲;

業(yè)務層對象使用該條件執(zhí)行查詢:

  1. detachedCriteria.getExecutableCriteria(session).list(); 

***的意義在于,業(yè)務層代碼是固定不變的,所有查詢條件的構(gòu)造都在web層完成,業(yè)務層只負責在session內(nèi)執(zhí)行之。這樣代碼就可放之四海而皆準,都無須修改了。然而Spring和Hibernate DetachedCriteria有不兼容的問題,因此在Spring環(huán)境下面使用Hibernate3需要注意:

Spring的HibernateTemplate提供了Hibernate的***封裝,即通過匿名類實現(xiàn)回調(diào),來保證Session的自動資源管理和事務的管理。其中核心方法是:

  1. HibernateTemplate.execute(new HibernateCallback() {  
  2. public Object doInHibernate(Session session) throws HibernateException {  
  3. ....  
  4. }  

回調(diào)方法提供了session作為參數(shù),有了session,就可以自由的使用Hibernate API編程了。使用了spring的之后,代碼修改如下:

  1. DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Department.class);  
  2. detachedCriteria.createAlias("employees", "e").
    add(Restrictions.eq("name", "department")).
    add(Restrictions.gt(("e.age"), new Integer(20)));  
  3. departmentManager.findByCriteria(detachedCriteria); 

【編輯推薦】

  1. Hibernate Util簡單討論
  2. 詳解優(yōu)化Hibernate性能經(jīng)驗
  3. 概述Hibernate dbcp連接池使用方法
  4. 淺析Hibernate.cfg.xml配置
  5. Hibernate Shard基礎分析
責任編輯:佚名 來源: 博客園
相關推薦

2009-09-28 10:05:27

Hibernate基礎

2009-09-22 10:46:00

Hibernate項目

2009-09-25 11:27:19

Hibernate J

2009-09-22 11:16:27

Hibernate經(jīng)驗

2009-09-22 17:25:41

優(yōu)化Hibernate

2009-09-29 16:32:11

OJB Hiberna

2009-09-27 14:53:38

Hibernate S

2009-09-25 17:26:55

使用Hibernate

2009-09-25 16:55:08

Hibernate初始

2009-09-28 12:57:54

Hibernate C

2009-09-23 11:21:32

學習Hibernate

2009-09-29 16:25:29

Hibernate c

2009-06-12 15:13:12

Hibernate學習

2009-09-29 17:22:30

Hibernate S

2009-09-10 17:38:04

LINQ技術

2009-09-11 12:08:09

Linq to SQL

2009-09-08 15:27:08

Linq Select

2009-09-07 17:09:45

Linq To Sql

2009-11-17 10:40:45

2009-08-13 17:50:49

Hibernate 3
點贊
收藏

51CTO技術棧公眾號