nhibernate資料載入之Criteria載入

來源:互聯網
上載者:User
載入|資料 Criteria是通過一組條件運算式(Expression)來載入資料的,它返回滿足條件的對象集合。

主要介面為ICriteria,實現為CriteriaImpl類,此類加有Internal修飾,因此不能在程式集外顯示建立,
nhibernate在session對象中為我們提供了一個方法CreateCriteria,此方法返回ICriteria介面。

這裡列出了ICriteria介面的一些方法:
SetMaxResults:設定返回的最大結果數,可用於分頁;
SetFirstResult:設定首個對象返回的位置,可用於分頁;
SetTimeout:設定作業的逾時值,此值將傳遞給IDbCommand對象;
Add:加入條件運算式(Expression對象),此方法可多次調用以組合多個條件;
AddOrder:加入排序的欄位(Order對象);
List:返回滿足條件的對象集合。

Criteria資料載入的關鍵就在Expression對象上,此對象組成了查詢語句的where部分。

Expression是一個abstract(抽象)類,它通過一組static方法實現Factory Method(Factory 方法)模式,這些static方法返回的都是Expression類的子類,下面列出一些常用的:

Eq:返回EqExpression,這是一個相等判斷的運算式;
Like:返回LikeExpression,這是一個like判斷的運算式;
Gt:返回GtExpression,這是一個大於判斷的運算式;
And:返回AndExpression,這是兩個運算式And操作後的運算式;
Or:返回OrExpression,這是兩個運算式Or操作後的運算式;

更多的Expression請參考相關文檔或原始碼。

下面以幾個例子來說明Criteria資料載入的用法:

1. 取得使用者名稱(username)為billy的使用者物件:

??? Expression ex = Expression.Eq( "Username", "billy" );
??? IList users = session.CreateCriteria(typeof(User)).Add( ex ).List();

2。取得使用者名稱(username)為billy, 密碼為123456的使用者物件

??? Expression ex = Expression.And( Expression.Eq("Username", "billy"),
??? Expression.Eq("Password", "123456") );
??? IList users = session.CreateCriteria(type(User)).Add( ex ).List();

3. 取得資料中第20-40的使用者物件。

??? IList users = session.CreateCriteria(typeof(User))
???????????????????????????? .SetFirstResult(20).SetMaxResults(40)
???????????????????????????? .List();

對於SQLSERVER,資料定位採用的是IDataReader前滾至firstResult處,然後取maxResults條記錄。

Criteria資料載入的不足:
1. 當使用SetFirstResult和SetMaxResults限制返回的對象數時,無法得知對象的總數;
2. 目前的版本不支援關聯查詢(hibernate好像可以);




相關文章

E-Commerce Solutions

Leverage the same tools powering the Alibaba Ecosystem

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。