天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

在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 子句,比如:   

update Table1 set Column1 = @Column1 , Column2 = @Column2 where ID = @original_ID and Column1 = @orignal_Column1 and Column2 = @original_Column2;

NET技術在ASP.NET 2.0中數據綁定的實現方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 日韩欧美视频一区二区在线观看 | 九九精品视频一区二区三区 | 国产人妻系列无码专区97SS | 韩国无遮羞禁动漫在线观看96 | 人妻中文字幕无码系列 | 亚洲国产精品无码中文字满 | 国产成人精品免费视频大全办公室 | 抽插的日日液液H | 四库影院永久国产精品 | 国产亚洲精品精品精品 | a级毛片高清免费视频 | 单亲妈妈3韩国电影免费观看 | 友田真希息与子中文字幕 | 高清日本片免费观看 | 国产AV亚洲一区精午夜麻豆 | 快播最新电影网站 | 欧美日韩亚洲一区视频二区 | 空姐内射出白浆10p 空姐厕所啪啪啪 | 国产亚洲欧美在线中文BT天堂网 | 99热这里只有 精品 99热这里只就有精品22 | 久久精品中文闷骚内射 | 国产自拍视频在线一区 | 亚洲三级在线中文字幕 | 快播成电影人网址 | 天美传媒色情原创精品 | 久久99r66热这里有精品 | 国精产品一区一区三区M | 亚洲伊人久久大香线蕉综合图片 | 精品国产在线国语视频 | 囯产愉拍亚洲精品一区 | 国产精品69人妻无码久久 | 暖暖日本大全免费观看 | 国产 高清 无码 在线播放 | av无码在线日本天堂 | 手机伊在人线香蕉2 | 99久久热视频只有精品 | 老司机福利视频一区在线播放 | 亚洲青青青网伊人精品 | 日韩欧美成人免费中文字幕 | 妈妈的职业3完整版在线播放 | 亚洲国产欧美国产综合在线 |