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

Hibernate過濾器使用竅門

開發(fā) 后端
Hibernate過濾器(filter)是全局有效的、具有名字、可以帶參數(shù)的過濾器,對(duì)于某個(gè)特定的Hibernate session您可以選擇是否啟用(或禁用)某個(gè)過濾器。

本文向大家介紹Hibernate過濾器,可能好多人還不了解Hibernate過濾器,沒有關(guān)系,看完本文你肯定有不少收獲,希望本文能教會(huì)你更多東西。

Hibernate3新增了對(duì)某個(gè)類或者集合使用預(yù)先定義的Hibernate過濾器條件(filter criteria)的功能。過濾器條件相當(dāng)于定義一個(gè) 非常類似于類和各種集合上的“where”屬性的約束子句,但是過濾器條件可以帶參數(shù)。

應(yīng)用程序可以在運(yùn)行時(shí)決定是否啟用給定的Hibernate過濾器,以及使用什么樣的參數(shù)值。 過濾器的用法很像數(shù)據(jù)庫(kù)視圖,只不過是在應(yīng)用程序中確定使用什么樣的參數(shù)的。

要使用過濾器,必須首先在相應(yīng)的映射節(jié)點(diǎn)中定義。而定義一個(gè)過濾器,要用到位于<hibernate-mapping/> 節(jié)點(diǎn)之內(nèi)的<filter-def/>節(jié)點(diǎn):

  1. <filter-def name="myFilter"> 
  2.  
  3.     <filter-param name="myFilterParam" type="string"/> 
  4.  
  5. </filter-def> 

定義好之后,就可以在某個(gè)類中使用這個(gè)過濾器:

  1. <class name="myClass" ...> 
  2.  
  3.     ...  
  4.  
  5.     <filter name="myFilter" condition=":myFilterParam = MY_FILTERED_COLUMN"/> 
  6.  
  7. </class> 

也可以在某個(gè)集合使用它:

  1. <set ...> 
  2.  
  3.     <filter name="myFilter" condition=":myFilterParam = MY_FILTERED_COLUMN"/> 
  4.  
  5. </set> 

可以在多個(gè)類或集合中使用某個(gè)過濾器;某個(gè)類或者集合中也可以使用多個(gè)過濾器。

Session對(duì)象中會(huì)用到的方法有:enableFilter(String filterName), getEnabledFilter(String filterName), 和 disableFilter(String filterName). Session中默認(rèn)是不啟用過濾器的,必須通過Session.enabledFilter()方法顯式的啟用。 該方法返回被啟用的Filter的實(shí)例。以上文定義的過濾器為例:

  1. session.enableFilter("myFilter").setParameter("myFilterParam", "some-value"); 

注意,org.hibernate.Filter的方法允許鏈?zhǔn)椒椒ㄕ{(diào)用。(類似上面例子中啟用Filter之后設(shè)定Filter參數(shù)這個(gè)“方法鏈”) Hibernate的其他部分也大多有這個(gè)特性。

下面是一個(gè)比較完整的例子,使用了記錄生效日期模式過濾有時(shí)效的數(shù)據(jù):

 

  1. <filter-def name="effectiveDate"> 
  2.  
  3.     <filter-param name="asOfDate" type="date"/> 
  4.  
  5. </filter-def> 
  6.  
  7.  
  8.  
  9. <class name="Employee" ...> 
  10.  
  11. ...  
  12.  
  13.     <many-to-one name="department" column="dept_id" class="Department"/> 
  14.  
  15.     <property name="effectiveStartDate" type="date" column="eff_start_dt"/> 
  16.  
  17.     <property name="effectiveEndDate" type="date" column="eff_end_dt"/> 
  18.  
  19. ...  
  20.  
  21.     <!--  
  22.  
  23.         Note that this assumes non-terminal records have an eff_end_dt set to  
  24.  
  25.         a max db date for simplicity-sake  
  26.  
  27.  
  28.  
  29.         注意,為了簡(jiǎn)單起見,此處假設(shè)雇用關(guān)系生效期尚未結(jié)束的記錄的eff_end_dt字段的值等于數(shù)據(jù)庫(kù)最大的日期  
  30.  
  31.     --> 
  32.  
  33.     <filter name="effectiveDate" 
  34.  
  35.             condition=":asOfDate BETWEEN eff_start_dt and eff_end_dt"/> 
  36.  
  37. </class> 
  38.  
  39.  
  40.  
  41. <class name="Department" ...> 
  42.  
  43. ...  
  44.  
  45.     <set name="employees" lazy="true"> 
  46.  
  47.         <key column="dept_id"/> 
  48.  
  49.         <one-to-many class="Employee"/> 
  50.  
  51.         <filter name="effectiveDate" 
  52.  
  53.                 condition=":asOfDate BETWEEN eff_start_dt and eff_end_dt"/> 
  54.  
  55.     </set> 
  56.  
  57. </class> 

定義好后,如果想要保證取回的都是目前處于生效期的記錄,只需在獲取雇員數(shù)據(jù)的操作之前先開啟過濾器即可:

  1. Session session = ...;  
  2.  
  3. session.enabledFilter("effectiveDate").setParameter("asOfDate", new Date());  
  4.  
  5. List results = session.createQuery("from Employee as e where e.salary > :targetSalary")  
  6.  
  7.          .setLong("targetSalary", new Long(1000000))  
  8.  
  9.          .list();  

在上面的HQL中,雖然我們僅僅顯式的使用了一個(gè)薪水條件,但因?yàn)閱⒂昧诉^濾器,查詢將僅返回那些目前雇用 關(guān)系處于生效期的,并且薪水高于一百萬(wàn)美刀的雇員的數(shù)據(jù)。

注意:

如果你打算在使用外連接(或者通過HQL或load fetching)的同時(shí)使用過濾器,要注意條件表達(dá)式的方向(左還是右)。 最安全的方式是使用左外連接(left outer joining)。并且通常來說,先寫參數(shù), 然后是操作符,最后寫數(shù)據(jù)庫(kù)字段名。

【編輯推薦】

  1. 淺述Hibernate性能優(yōu)化
  2. Hibernate傳播性持久化攻略
  3. 深索Hibernate延遲加載技術(shù)
  4. 深入了解Hibernate自動(dòng)狀態(tài)檢測(cè)
  5. Hibernate擴(kuò)展周期的Session和自動(dòng)版本化
責(zé)任編輯:仲衡 來源: IT168
相關(guān)推薦

2009-09-29 13:55:23

Hibernate設(shè)置

2009-06-18 10:13:00

Hibernate過濾

2021-07-05 15:22:03

Servlet過濾器客戶端

2024-01-05 09:04:35

隆過濾器數(shù)據(jù)結(jié)構(gòu)哈希函數(shù)

2024-11-04 08:45:48

布隆過濾器元數(shù)據(jù)指紋值

2009-07-08 15:30:56

Servlet過濾器

2009-07-08 16:07:04

Servlet過濾器配

2009-07-14 09:09:08

Swing模型過濾器

2011-06-29 16:14:59

Qt 事件 過濾器

2025-04-21 00:50:50

2022-10-11 23:14:39

模態(tài)循環(huán)過濾器代碼

2017-07-18 14:10:31

大數(shù)據(jù)Apache Flum過濾器

2009-07-08 17:33:37

Servlet過濾器

2020-10-29 07:16:26

布隆過濾器場(chǎng)景

2009-07-06 13:02:49

Servlet過濾器

2024-03-15 11:21:22

布隆過濾器數(shù)據(jù)庫(kù)數(shù)據(jù)

2023-01-26 01:41:27

核心全局過濾器

2016-12-07 09:56:13

JavaFilter過濾器

2010-03-01 14:45:07

Linux文件重定向

2017-04-12 14:43:01

Spring ClouZuul過濾器
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)