【C#.NET】ASP.NET 2.0 資料繫結概述)

來源:互聯網
上載者:User
1、為什麼ASP.NET 2.0中的資料繫結控制項不需要寫代碼就能完成更新、刪除、建立等資料操作?
在ASP.NET 1.x時,DataGrid等控制項使用DataBinder.Eval(Container.DataItem,"ColumnName")這樣的運算式可以將資料來源中的資料繫結到控制項上,但並不能在更新資料時自動將控制項中的新值取出,更新回資料庫。所以ASP.NET 2.0中的資料繫結分為兩種:單向資料繫結(即<%# Eval("ColumnName")%>運算式或ReadOnly設為True的BoundField,只提供從資料來源到控制項的資料繫結)和雙向資料繫結(<%# Bind("ColumnName")%>,不但可以將資料從資料來源綁定到控制項,而且可以在操作資料時將控制項中的資料提供給資料來源控制項),所以ASP.NET 2.0操作資料時就不需要寫大量e.Item.FindControl()這樣的代碼了。

2、在Update和Insert過程中,GridView/DetailsView/FormView是如何把值傳遞給資料來源控制項,以便資料來源控制項完成資料操作方法的調用的?
更新時,GridView會提供兩套值給資料來源控制項,一套新值,彙集所有ReadOnly不為True的列的值和模板中所有<%#Bind()%>運算式的值,另一套舊的值,則從當前行對應的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 子句,比如:
update Table1 set Column1 = @Column1 , Column2 = @Column2 where ID = @original_ID and Column1 = @orignal_Column1 and Column2 = @original_Column2。強型別資料集通過在進階選項上選中開放式並發的選鉤可以自動產生這樣的命令。根據我們第2點的論述,只需在GirdView的DatakeyNames屬性中把所有的欄位都加進去,這樣就會自動的把舊的值放進老值集合中,滿足資料來源的要求。由此,我們可以理解為什麼DataGrid的DataKeyField(單數)屬性會被替換為DataKeyNames屬性(複數)。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.