ASP.Net2.0裡面的ObjectDataSource可以使數據顯示控件GridVIEw等進行綁定顯示,編輯。還可以支持內置的分頁,排序等。使用了ORM之後,一樣可以使用ObjectDataSource。
這裡的分頁不再是從數據庫取出所有,然後選擇性綁定,而是直接在數據庫取出第幾頁,然後綁定。這個差別還是十分巨大的,效率大大提高。
編輯,創建,排序也都是,直接由ObjectDataSource提供,不需要再GridVIEw中寫什麼代碼。
這樣,可以把Object設計的包含有不少邏輯,至少是對數據庫操作的,而UI就顯得比較簡單,剝離的再開一點,對以後移植到win上,或者做成SmartClIEnt都比較有益。
這裡有一片blog,講的比較好http://www.evosoftworks.com/Articles/wormods.ASPx。
我用的正好也是WilsonORM,所以照此也作了一個。
基本的結構是這樣的:
UI(GridVIEw等控件--ObjectDataSource控件)----〉ObjectDataSource類(Object,寫CRUD分頁等邏輯)---〉(ORM實現CRUD)---〉DB
主要有幾步
1:給Object增加屬性和方法,來完成CRUD,分頁等邏輯
2:配置GridVIEw等UI控件連接到ObjectDataSource控件。
先看第一個
1:給Object增加屬性和方法,來完成CRUD,分頁等邏輯。該Object類由工具根據DB結構生成,同時生成的還有Mapping文件。
首先,給該Object增加一個標示屬性DataObject(),在System.ComponentModel命名空間裡面 [DataObject()]
public class ProductDescription
{ 第二,給這個object類增加CRUD的方法。
先看一個Insert方法
[DataObjectMethod(DataObjectMethodType.Insert)]
public static void Insert(ProductDescription productDescription)
{
try
{
Manager.DataManager.StartTracking(productDescription, InitialState.Inserted);
Manager.DataManager.PersistChanges(productDescription);
}
catch (Exception ex)
{
log.Error(ex);
}
} 這個方法前面需要加一個[DataObjectMethod(DataObjectMethodType.Insert)]屬性,表示這是Insert方法;
這個方法是靜態公開的方法;
參數,就是這個Object本身的一個實例。這樣比較好,因為在邏輯好很好理解,都是在對Object進行操作。
剩下的,Delete,Update方法也是這樣寫。
然後看看Select方法,比較特殊。
Select方法
1 [DataObjectMethod(DataObjectMethodType.Select)]
2 public Collection<ProductDescription> RetrIEve(string query, int maxRows, int startRowIndex, string sortClause)
3 {
4 try
5&nb
sp; {
6 int numPages = 0;
7 if (sortClause == null || sortClause == "")
8 sortClause = "ModifIEdDate Desc";
9 Collection<ProductDescription> cs;
10 cs = RetrIEvePage(query, sortClause, maxRows, (int)Math.Ceiling((double)startRowIndex / maxRows) + 1, out numPages);
11 _numRecs = ((IObjectPage)cs).TotalCount;
12 return cs;
13 }
14 catch (Exception ex)
15 {
16 log.Error(ex);
17 return null;
18 }
19 }
20 [DataObjectMethod(DataObjectMethodType.Select)]
21 static public ObjectSet RetrIEve(string Key, string Value)
22 {
23 if (Value == null || Value == "")
24 return null;
25 try
26 {
27 QueryHelper helper = Manager.DataManager.QueryHelper;
28 Key = helper.GetFIEldName(typeof(ProductDescription).ToString() + "." + Key);
29 ObjectQuery query = new ObjectQuery(typeof(ProductDescription), String.Format("{0}='{1}'", Key, Value), "");
30 ObjectSet obj = Manager.DataManager.GetObjectSet(query);
31 &nbs
p; return obj;
32 }
33 catch (Exception ex)
34 {
35 log.Error(ex);
36 return null;
37 }
38 }
39
40 public int RecCount(string query, int maxRows, int startRowIndex, string sortClause)
41 {
42 return _numRecs;
43 }
44
45 public static Collection<ProductDescription> RetrIEvePage(string whereClause, string sortClause, int pageSize, int pageIndex, out int pageCount)
46 {
47 ObjectQuery<ProductDescription> query = new ObjectQuery<ProductDescription>(whereClause, sortClause, pageSize, pageIndex);
48 ObjectSet<ProductDescription> pageSet = Manager.DataManager.GetObjectSet<ProductDescription>(query);
49 pageCount = pageSet.PageCount;
50 return pageSet;
51 } 第一個方法public Collection<ProductDescription> RetrIEve(string query, int maxRows, int startRowIndex, string sortClause),這是可以實現內置分頁,和排序的方法。需要注意的是這句代碼_numRecs = ((IObjectPage)cs).TotalCount; 在這裡,分頁之後,立即取出總頁數,這個是用來供顯示頁號的;於此對應,方法 public int RecCount(string query, int maxRows, int startRowIndex, string sortClause)就是用來取出記錄條數的;注意,這兩個方法一定要對應,參數也一樣。
第二個方法 static public ObjectSet Retrieve(string Key, string Value)只是普通的取出一條紀錄。可以用在DetailView/FormVIEw的顯示。
代碼看上去雖然很多,但是其實很模式化,所以可以使用CodeSmith或者直接修改一下ORMHelper工具來動態生成,不需要手工寫代碼。
有了這四個方法,CRUD,分頁,排序就已經完成了。這樣的Object,和UI無關,只是數據邏輯。
2:UI的配置。UI配置也分兩層:GridVIEw等顯示控件;ObjectDataSource控件
現在給GridVIEw等控件配置Object數據源,直接連接到Object上,實現顯示編輯等功能。其實就是設置一個連接到ObjectDataSource的屬性。
<ASP:GridVIEw ID="gv_data" runat="server" AllowPaging="True" AllowSorting="T
rue" DataSourceID="ods_list"
這是ObjectDataSource控件的配置
ObjectDataSource
1<ASP:ObjectDataSource ID="ods_list" runat="server" DataObjectTypeName="BusinessModel.ProductDescription"
2 DeleteMethod="Delete" OldValuesParameterFormatString="original_{0}" SelectMethod="RetrIEve"
3 TypeName="BusinessModel.ProductDescription" UpdateMethod="Update" SortParameterName="sortClause"
4 MaximumRowsParameterName="maxRows" SelectCountMethod="RecCount" EnablePaging="true"
5 ConflictDetection="OverwriteChanges" ConvertNullToDBNull="false">
6 <SelectParameters>
7 <ASP:Parameter Name="query" Type="String" />
8 <ASP:Parameter Name="maxRows" Type="Int32" />
9 <ASP:Parameter Name="startRowIndex" Type="Int32" />
10 <ASP:Parameter Name="sortClause" Type="String" />
11 </SelectParameters>
12</ASP:ObjectDataSource>
看看裡面的屬性,就是配置CRUD方法的參數,和對應的方法名。這些正是我們在類中實現的。比方說這裡配置Delete方法:DeleteMethod="Delete";而這裡就是剛才說的記錄個數的屬性:SelectCountMethod="RecCount";還有排序等等。
這裡的參數怎麼傳遞?系統相關的屬性由系統傳遞,比方說,maxRows,startRowIndex什麼的;也可以用代碼來傳遞: this.ods_list.SelectParameters["query"].DefaultValue = query;
http://dlwang2002.cnblogs.com/archive/2006/06/11/422991.Html