一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

Asp.net2.0:如何使用ObjectDataSource

 ylzrx 2012-02-10
asp.net2.0里面的ObjectDataSource可以使數(shù)據(jù)顯示控件GridView等進行綁定顯示,編輯。還可以支持內(nèi)置的分頁,排序等。使用了ORM之后,一樣可以使用ObjectDataSource。

這里的分頁不再是從數(shù)據(jù)庫取出所有,然后選擇性綁定,而是直接在數(shù)據(jù)庫取出第幾頁,然后綁定。這個差別還是十分巨大的,效率大大提高。
編輯,創(chuàng)建,排序也都是,直接由ObjectDataSource提供,不需要再GridView中寫什么代碼。
這樣,可以把Object設(shè)計的包含有不少邏輯,至少是對數(shù)據(jù)庫操作的,而UI就顯得比較簡單,剝離的再開一點,對以后移植到win上,或者做成SmartClient都比較有益。

這里有一片blog,講的比較好http://www./Articles/wormods.aspx。

我用的正好也是WilsonORM,所以照此也作了一個。

基本的結(jié)構(gòu)是這樣的:
UI(GridView等控件--ObjectDataSource控件)----〉ObjectDataSource類(Object,寫CRUD分頁等邏輯)---〉(ORM實現(xiàn)CRUD)---〉DB

主要有幾步
1:給Object增加屬性和方法,來完成CRUD,分頁等邏輯
2:配置GridView等UI控件連接到ObjectDataSource控件。


先看第一個
1:給Object增加屬性和方法,來完成CRUD,分頁等邏輯。該Object類由工具根據(jù)DB結(jié)構(gòu)生成,同時生成的還有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方法;
       這個方法是靜態(tài)公開的方法;
       參數(shù),就是這個Object本身的一個實例。這樣比較好,因為在邏輯好很好理解,都是在對Object進行操作。
       剩下的,Delete,Update方法也是這樣寫。
       然后看看Select方法,比較特殊。
 

 1        [DataObjectMethod(DataObjectMethodType.Select)]
 2        public Collection<ProductDescription> Retrieve(string query, int maxRows, int startRowIndex, string sortClause)
 3        {
 4            try
 5            {
 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) + 1out 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                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),這是可以實現(xiàn)內(nèi)置分頁,和排序的方法。需要注意的是這句代碼_numRecs = ((IObjectPage)cs).TotalCount; 在這里,分頁之后,立即取出總頁數(shù),這個是用來供顯示頁號的;于此對應(yīng),方法 public int RecCount(string query, int maxRows, int startRowIndex, string sortClause)就是用來取出記錄條數(shù)的;注意,這兩個方法一定要對應(yīng),參數(shù)也一樣。
          第二個方法 static public ObjectSet Retrieve(string Key, string Value)只是普通的取出一條紀錄??梢杂迷贒etailView/FormView的顯示。
           代碼看上去雖然很多,但是其實很模式化,所以可以使用CodeSmith或者直接修改一下ORMHelper工具來動態(tài)生成,不需要手工寫代碼。
           有了這四個方法,CRUD,分頁,排序就已經(jīng)完成了。這樣的Object,和UI無關(guān),只是數(shù)據(jù)邏輯。

2:UI的配置。UI配置也分兩層:GridView等顯示控件;ObjectDataSource控件
       現(xiàn)在給GridView等控件配置Object數(shù)據(jù)源,直接連接到Object上,實現(xiàn)顯示編輯等功能。其實就是設(shè)置一個連接到ObjectDataSource的屬性。
       
<asp:GridView ID="gv_data" runat="server" AllowPaging="True" AllowSorting="True" DataSourceID="ods_list"

       
        這是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方法的參數(shù),和對應(yīng)的方法名。這些正是我們在類中實現(xiàn)的。比方說這里配置Delete方法:DeleteMethod="Delete";而這里就是剛才說的記錄個數(shù)的屬性:SelectCountMethod="RecCount";還有排序等等。
         這里的參數(shù)怎么傳遞?系統(tǒng)相關(guān)的屬性由系統(tǒng)傳遞,比方說,maxRows,startRowIndex什么的;也可以用代碼來傳遞:
 this.ods_list.SelectParameters["query"].DefaultValue = query;

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多

    精品国产成人av一区二区三区| 久久精品蜜桃一区二区av| 一区中文字幕人妻少妇| 日韩国产传媒在线精品| 国产丝袜极品黑色高跟鞋| 日韩高清中文字幕亚洲| 亚洲一区二区欧美在线| 久热久热精品视频在线观看 | 欧美人禽色视频免费看| 美日韩一区二区精品系列| 亚洲一区二区欧美激情| 精品少妇一区二区三区四区| 国产成人国产精品国产三级| 中文字日产幕码三区国产| 亚洲国产色婷婷久久精品| 欧美日韩综合免费视频| 东京干男人都知道的天堂| 热情的邻居在线中文字幕| 国产欧美一区二区色综合| 情一色一区二区三区四| 成人国产一区二区三区精品麻豆| 乱女午夜精品一区二区三区| 99久久精品午夜一区二| 日本午夜精品视频在线观看| 国产毛片不卡视频在线| 国产精品不卡高清在线观看| 日本东京热加勒比一区二区| 熟女体下毛荫荫黑森林自拍| 日本午夜福利视频免费观看| 免费观看一区二区三区黄片| 91日韩在线观看你懂的| 国产女性精品一区二区三区 | 久久国内午夜福利直播| 国产日韩综合一区在线观看| 午夜视频成人在线免费| 色一情一乱一区二区三区码| 亚洲精品成人福利在线| 中文字幕一区久久综合| 国内胖女人做爰视频有没有| 国产日韩久久精品一区| 国产精品午夜福利在线观看|