天天看點

一起談.NET技術,在ASP.NET 2.0中資料綁定的實作方法

1、為什麼ASP.NET 2.0中的資料綁定控件不需要寫代碼就能完成更新、删除、建立等資料操作?

  ASP.NET 1.x時,DataGrid等控件使用DataBinder.Eval(Container.DataItem,"ColumnName")這樣的表達式可以将資料源中的資料綁定到控件上,但并不能在更新資料時自動将控件中的新值取出,更新回資料庫。是以ASP.NET 2.0中的資料綁定分為兩種:單向資料綁定(即表達式或ReadOnly設為True的BoundField,隻提供從資料源到控件的資料綁定)和雙向資料綁定(,不但可以将資料從資料源綁定到控件,而且可以在操作資料時将控件中的資料提供給資料源控件),是以ASP.NET 2.0操作資料時就不需要寫大量e.Item.FindControl()這樣的代碼了。

  2、在Update和Insert過程中,GridView/DetailsView/FormView是如何把值傳遞給資料源控件,以便資料源控件完成資料操作方法的調用的?

  更新時,GridView會提供兩套值給資料源控件,一套新值,彙集所有ReadOnly不為True的列的值和模闆中所有表達式的值,另一套舊的值,則從目前行對應的DataKey中獲得(DataKey的值在綁定資料時就會被GridView儲存到視圖狀态中),可以在GridView的Updating事件處理程式中看到這一特征。舊的那套值提供給資料源控件後,它的Key會被資料源控件根據OldValuesParameterFormatString重命名。比如,GridView中的DataKeyNames設為ProductID,資料源控件的OldValuesParameterFormatString為original_{0},那麼GridView在更新時傳給資料源控件的參數中就會有一個original_ProductID。

  新的那套值和老的那套值合起來要剛好和資料源控件需要的參數清單相比對,不能多也不能少,這是初學者使用GridView更新資料時遇到最多的問題。

  實際使用過程中如果主鍵列對應的參數(比如,ProductID),沒有像Strong named Dataset那樣取名為original_ProductID,則需要更改資料源的OldValuesParameterFormatString,比如改成{0},這樣才能和實作方法的參數對應起來。

  3、如何實作開放式并發?

  開放式并發的更新和删除語句會有一個很長的where 子句,比如:   

  強類型資料集通過在進階選項上選中開放式并發的選鈎可以自動生成這樣的指令。根據我們第2點的論述,隻需在GirdView的DatakeyNames屬性中把所有的字段都加進去,這樣就會自動的把舊的值放進老值集合中,滿足資料源的要求。由此,我們可以了解為什麼DataGrid的DataKeyField(單數)屬性會被替換為DataKeyNames屬性(複數)。

繼續閱讀