YbSoftwareFactory 的 YbRapidSolution for WinForm 插件使用CSLA.NET作為業務層,CSLA.NET的一個強大的特性是支持 N-Tiers 部署。只需非常簡單的配置就能在本1-Tier部署方式和N-Tiers部署方式之間切換,這個過程無需編寫任何額外的代碼,這對於 WinForm 和 WPF 等客戶端的開發來說是非常重要的特性,更多信息請參考我前面的文章:YbSoftwareFactory 代碼生成插件【七】:YbRapidSolution for WinForm 插件生成項目總體架構介紹。但眾所周知,VS 在 WinForm 的開發環境下沒有提供相應的分頁控件,網上很多針對實現的分頁控件雖然實現了數據庫分頁但往往也要丟失一些在WinForm下的重要特性,通用性和易用性都稍差。本文描述了通過 DynamicLinq 來實現非常方便的自定義過濾條件和自定義排序規則的服務器端數據庫分頁,並提供 DynamicLinq 的代碼下載。
YbRapidSolution for WinForm 插件解決方案的界面層使用DevExpress,DevExpress 的 GridContro l控件比 VS 自帶的 DataGridView 不知強大多少倍,自定義過濾、分組、統計、列選擇等一氣呵成,甚至連數據的導出也非常的全面和方便。但如果不進行數據庫分頁的話往往性能低下,DevExpreess 可以通過實現 IListserver 提升大數量下的性能,但在 N-Tier 模式下實現的難度和復雜程度超乎想象,我們此處將通過采用折中的解決方案。
在我前面介紹的 YbRapidSolution for MVC 插件中,已經使用了 DynamicLinq 來進行查詢、分頁和排序,而在 WinForm 插件中我們同樣使用 DynamicLinq 來實現類似的分頁效果。通過使用 DynamicLinq 后,不僅保留了 DevExpress 的GridControl 控件的一些主要特性,性能的提升也是顯而易見的。首先來看看幾張分頁效果的大圖:
1、 分頁總體效果圖(服務層端的數據庫分頁):

2、 可任意列進行排序

3、可自定義查詢條件,注意此處可是跨表查詢

4、支持組合查詢和其他字段類型

本方案的實現效果很好,也非常靈活,所有的分頁數據均來源於服務層而不是直接來源於數據層。更關鍵的是所需的代碼量極少,如下就是本模塊的簡單的分頁調用代碼:
2 {
3 var result = new OrdersList();
4 result.RaiseListChangedEvents = false;
5 SetIsReadOnly(result, false);
6 var data = _repository.Table;
7 if (! string.IsNullOrWhiteSpace(criteria.Filter1))
8 {
9 data = data.Where(criteria.Filter1);
10 }
11 result.TotalRowCount = data.Count();
12 if ( string.IsNullOrWhiteSpace(criteria.Sort))
13 {
14 criteria.Sort = " OrderID ";
15 }
16 data = data.OrderBy( string.Format( " {0} {1} ", criteria.Sort, criteria.Order));
17 if (criteria.Page <= 0)
18 criteria.Page = 1;
19 var items = data.Skip((criteria.Page - 1) * criteria.Rows).Take(criteria.Rows).ToList();
20
21 foreach ( var item in items)
22 {
23 result.Add(EntityToBusinessObject(item));
24 }
25
26 result.RaiseListChangedEvents = true;
27 SetIsReadOnly(result, true);
28
29 return result;
30
同時附上即將實現的一個流程設計器界面:

在下一章中,我們將介紹如何實現屬性自動擴展並可方便地從數據庫中加載和保存的解決方案。
附件:DynamicLinq 下載地址: DynamicLinq