程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> Asp.net2.0:如何使用ObjectDataSource(配合ORM)

Asp.net2.0:如何使用ObjectDataSource(配合ORM)

編輯:.NET實例教程


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

  1. 上一頁:
  2. 下一頁: