Junky's IT Notebook

          統(tǒng)計

          留言簿(8)

          積分與排名

          WebSphere Studio

          閱讀排行榜

          評論排行榜

          Hibernate 深入研究之 Criteria (轉(zhuǎn))

          最近在項目中使用 Spring 和 Hibernate 進行開發(fā),有感于 Criteria 比較好用,在查詢方法設(shè)計上可以靈活的根據(jù) Criteria 的特點來方便地進行查詢條件的組裝。所以現(xiàn)在對 Hibernate 的 Criteria 深入研究一下?!?Hibernate Reference 》及網(wǎng)上其它一些資料對 Criteria 已經(jīng)做了很多介紹。

          最近在項目中使用 Spring Hibernate 進行開發(fā),有感于 Criteria 比較好用,在查詢方法設(shè)計上可以靈活的根據(jù) Criteria 的特點來方便地進行查詢條件的組裝。所以現(xiàn)在對 Hibernate Criteria 深入研究一下。《 Hibernate Reference 》及網(wǎng)上其它一些資料對 Criteria 已經(jīng)做了很多介紹。本文主要是從 Criteria 的結(jié)構(gòu)入手來進行分析。

          ?????? 如圖 1 。 Hibernate 設(shè)計了 CriteriaSpecification 作為 Criteria 的頂級接口,其下面提供了 Criteria DetachedCriteria 。

          Criteria DetachedCriteria 的主要區(qū)別在于創(chuàng)建的形式不一樣, Criteria 是在線的,所以它是由 Hibernate Session 進行創(chuàng)建的;而 DetachedCriteria 是離線的,創(chuàng)建時無需 Session , DetachedCriteria 提供了 4 個靜態(tài)方法 forClass(Class) forEntityName(Name) 進行 DetachedCriteria 實例的創(chuàng)建。 Spring 的框架提供了

          getHibernateTemplate().findByCriteria(detachedCriteria) 方法可以很方便地根據(jù)

          DetachedCriteria 來返回查詢結(jié)果。

          如圖 1 , Criteria DetachedCriteria 均可使用 Criterion Projection 設(shè)置查詢條件??梢栽O(shè)置 FetchMode( 聯(lián)合查詢抓取的模式 ) ,設(shè)置排序方式。對于 Criteria 還可以設(shè)置 FlushModel (沖刷 Session 的方式)和 LockMode (數(shù)據(jù)庫鎖模式)。

          下面就對 Criterion Projection 進行詳細說明。

          ??????

          1

          ?

          ?????? Criterion Criteria 的查詢條件。

          Criteria 提供了 add(Criterion criterion) 方法來添加查詢條件。圖 2 Criterion 的結(jié)構(gòu)圖。 Criterion 接口的主要實現(xiàn)包括: Example 、 Junction SimpleExpression 。而 Junction 的實際使用是它的兩個子類 conjunction disjunction ,分別是使用 AND OR 操作符進行來聯(lián)結(jié)查詢條件集合。

          Criterion 的實例可以通過 Restrictions 工具類來創(chuàng)建, Restrictions 提供了大量的靜態(tài)方法,如 eq (等于)、 ge (大于等于)、 between 等來方法的創(chuàng)建 Criterion 查詢條件

          SimpleExpression 實例)。除此之外, Restrictions 還提供了方法來創(chuàng)建 conjunction disjunction 實例,通過往該實例的 add(Criteria) 方法來增加查詢條件形成一個查詢條件集合。

          至于 Example 的創(chuàng)建有所不同, Example 本身提供了一個靜態(tài)方法 create(Object entity) ,即根據(jù)一個對象(實際使用中一般是映射到數(shù)據(jù)庫的對象)來創(chuàng)建。然后可以設(shè)置一些過濾條件:

          Example exampleUser =Example.create(u)

          .ignoreCase() // 忽略大小寫

          .enableLike(MatchMode.ANYWHERE);

          // String 類型的屬性,無論在那里值在那里都匹配。相當于 %value%


          2

          ??????

          Project 主要是讓 Criteria 能夠進行報表查詢,并可以實現(xiàn)分組。 Project 主要有 SimpleProjection 、 ProjectionList Property 三個實現(xiàn)。其中 SimpleProjection ProjectionList 的實例化是由內(nèi)建的 Projections 來完成,如提供的 avg count max 、 min sum 可以讓開發(fā)者很容易對某個字段進行統(tǒng)計查詢。

          ?????? Property 是對某個字段進行查詢條件的設(shè)置,如通過

          ????? Porperty.forName(“color”).in(new String[]{“black”,”red”,”write”}); 則可以創(chuàng)建一個 Project 實例。通過 criteria add(Project) 方法加入到查詢條件中去。


          3

          ??????

          ?????? 使用 Criteria 進行查詢,主要要清晰的是 Hibernate 提供了那些類和方法來滿足開發(fā)中查詢條件的創(chuàng)建和組裝,其結(jié)構(gòu)層次如何。這樣使用起來便可得心應(yīng)手。

          ?

          posted on 2007-03-16 13:34 junky 閱讀(566) 評論(0)  編輯  收藏 所屬分類: hibernate

          主站蜘蛛池模板: 兰坪| 微山县| 漯河市| 万载县| 夏河县| 隆林| 定州市| 台东市| 隆化县| 闵行区| 夏河县| 雅安市| 内乡县| 黄石市| 凤城市| 大理市| 六安市| 澄城县| 射阳县| 普安县| 天长市| 华宁县| 清徐县| 瑞安市| 莫力| 青浦区| 揭阳市| 通州区| 青阳县| 德州市| 荣成市| 资兴市| 常宁市| 固原市| 抚宁县| 崇信县| 什邡市| 宜城市| 常熟市| 巩留县| 沐川县|