版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、在ASP.NET 2.0中操作數(shù)據(jù)之十六:概述插入、更新和刪除數(shù)據(jù)作者:heker2007 字體:增加 減小 類(lèi)型:轉(zhuǎn)載 時(shí)間:2016-05-06 我要評(píng)論本文主要介紹ASP.NET中插入、更新和刪除數(shù)據(jù)的原理,ObjectDataSource在頁(yè)面和潛在的數(shù)據(jù)之間扮演一個(gè)代理的角色,配合業(yè)務(wù)邏輯可以執(zhí)行Select()、Insert()、Update()和Delete()方法。導(dǎo)言結(jié)束前面的幾節(jié),我們已經(jīng)探討過(guò)了如何使用GridView、DetailsView和FormView控件來(lái)顯示數(shù)據(jù)。這些控件簡(jiǎn)單地操作提供給它的數(shù)據(jù)。一般地,這些控件通過(guò)使用一個(gè)數(shù)據(jù)源控件,例如
2、ObjectDataSource來(lái)存取數(shù)據(jù)。我們已經(jīng)看過(guò)了ObjectDataSource是如何在ASP.NET頁(yè)面和潛在的數(shù)據(jù)之間扮演一個(gè)代理的角色。當(dāng)一個(gè)GridView需要顯示數(shù)據(jù)時(shí),它調(diào)用ObjectDataSource的Select()方法,這個(gè)方法轉(zhuǎn)而調(diào)用一個(gè)來(lái)自我們的業(yè)務(wù)邏輯層(BLL)的方法,繼而調(diào)用一個(gè)適當(dāng)?shù)臄?shù)據(jù)訪問(wèn)層(DAL)的表適配器(TableAdapter)的方法,從而它發(fā)送一個(gè)SELECT查詢(xún)到Northwind數(shù)據(jù)庫(kù)。記得在我們的教程里當(dāng)創(chuàng)建DAL中的表適配器時(shí),Visual Studio自動(dòng)地添加從潛在數(shù)據(jù)庫(kù)插入、更新和刪除數(shù)據(jù)的方法。此外,在創(chuàng)建一個(gè)業(yè)務(wù)邏輯層
3、這一節(jié)我們已經(jīng)設(shè)計(jì)了調(diào)用這些數(shù)據(jù)更改的DAL方法的BLL方法。除了它的Select()方法,ObjectDataSource還有Insert()、Update()和Delete()方法。跟Select()方法類(lèi)似,這三個(gè)方法映射到一個(gè)隱含的對(duì)象。當(dāng)配置插入、更新或刪除數(shù)據(jù)時(shí),GridView、DetailsView和FormView控件提供了一個(gè)修改潛在的數(shù)據(jù)的用戶(hù)界面。這個(gè)用戶(hù)界面調(diào)用ObjectDataSource的Insert()、Update()和Delete()方法,它們繼而調(diào)用隱含對(duì)象的關(guān)聯(lián)方法(見(jiàn)圖1)。圖 1: ObjectDataSource的Insert()、Update(
4、)和Delete()方法提供一個(gè)到BLL的代理本節(jié)我們將看看如何映射ObjectDataSource的Insert()、Update()和Delete()方法到BLL中的類(lèi),也看看如何配置GridView、DetailsView和FormView控件提供修改數(shù)據(jù)的功能。第一步: 創(chuàng)建Insert、Update和Delete教程頁(yè)面在我們開(kāi)始探討如何插入、修改和刪除數(shù)據(jù)之前,讓我們先花些時(shí)間在我們的站點(diǎn)項(xiàng)目里添加這些本節(jié)里和下一節(jié)里需要的ASP.NET頁(yè)面。首先添加一個(gè)名為EditInsertDelete的新文件夾。然后,在這個(gè)文件夾里添加下面這些ASP.NET頁(yè)面,并且確認(rèn)每個(gè)頁(yè)面都關(guān)聯(lián)Sit
5、e.master母版頁(yè):·Default.aspx·Basics.aspx·DataModificationEvents.aspx·ErrorHandling.aspx·UIValidation.aspx·CustomizedUI.aspx·OptimisticConcurrency.aspx·ConfirmationOnDelete.aspx·UserLevelAccess.aspx圖 2: 添加這些與數(shù)據(jù)更改關(guān)聯(lián)的教程的頁(yè)面類(lèi)似在其它文件夾里,EditInsertDelete文件夾里的Default.
6、aspx將列出這些教程章節(jié)。記得用戶(hù)控件提供這個(gè)功能。因此,從解決方案資源管理器中拖拽一個(gè)這個(gè)用戶(hù)控件到頁(yè)面的設(shè)計(jì)視圖,從而添加它到Default.aspx頁(yè)面。圖 3: 添加SectionLevelTutorialListing.ascx用戶(hù)控件到tDefault.aspx頁(yè)面最后,添加這些頁(yè)面地址項(xiàng)到Web.sitemap文件。明確地,在Customized Formatting <siteMapNode>后添加如下標(biāo)記:?12345678910111213141516171819202122232425262728293031323334<siteMapNode tit
7、le="Editing, Inserting, and Deleting" url="/EditInsertDelete/Default.aspx" description="Samples of Reports that Provide Editing, Inserting, and Deleting Capabilities"> <siteMapNo
8、de url="/EditInsertDelete/Basics.aspx" title="Basics" description="Examines the basics of data modification with the GridView, DetailsView, and FormView controls.&q
9、uot; /> <siteMapNode url="/EditInsertDelete/DataModificationEvents.aspx" title="Data Modification Events" description="Explores the events raised by the ObjectDataSource &
10、#160; pertinent to data modification." /> <siteMapNode url="/EditInsertDelete/ErrorHandling.aspx" title="Error Handling" description="Learn how to gracefully handle exceptions raised
11、160; during the data modification workflow." /> <siteMapNode url="/EditInsertDelete/UIValidation.aspx" title="Adding Data Entry Validation" description="H
12、elp prevent data entry errors by providing validation." /> <siteMapNode url="/EditInsertDelete/CustomizedUI.aspx" title="Customize the User Interface" description="Customize the editing and inserting user in
13、terfaces." /> <siteMapNode url="/EditInsertDelete/OptimisticConcurrency.aspx" title="Optimistic Concurrency" description="Learn how to help prevent simultaneous users from
14、 overwritting one another s changes." /> <siteMapNode url="/EditInsertDelete/ConfirmationOnDelete.aspx" title="Confirm On Delete" description="Prompt a user for confirmation when
15、 deleting a record." /> <siteMapNode url="/EditInsertDelete/UserLevelAccess.aspx" title="Limit Capabilities Based on User" description="Learn how to limit the data modification functionality
16、; based on the user role or permissions." /></siteMapNode>在更新了Web.sitemap后,花些時(shí)間通過(guò)瀏覽器訪問(wèn)本教程站點(diǎn)。左邊的菜單里現(xiàn)在包含對(duì)應(yīng)編輯、插入和刪除教程的項(xiàng)。圖 4: 站點(diǎn)地圖現(xiàn)在包含了對(duì)應(yīng)編輯、插入和刪除教程的項(xiàng)第二步: 添加并配置ObjectDataSource控件因?yàn)镚ridView、DetailsView和FormView控件在數(shù)據(jù)修改功能和版面上都有所不同,就讓我們逐個(gè)研究。不過(guò),與其讓這
17、三個(gè)控件各自使用自己的ObjectDataSource,還不如讓我們僅創(chuàng)建一個(gè)ObjectDataSource讓這個(gè)三個(gè)控件的例子共用。打開(kāi)Basics.aspx頁(yè)面,從工具箱拖拽一個(gè)ObjectDataSource到設(shè)計(jì)器,從它的職能標(biāo)記中點(diǎn)擊配置數(shù)據(jù)源鏈接。因?yàn)镻roductsBLL類(lèi)是唯一一個(gè)提供修改、插入和刪除方法的BLL類(lèi),配置該ObjectDataSource使用這個(gè)類(lèi)。圖 5: 配置ObjectDataSource使用ProductsBLL類(lèi)在下一屏中,通過(guò)選擇適當(dāng)?shù)膖ab頁(yè)并從下拉列表中選擇方法,我們可以指定ProductsBLL類(lèi)里的哪些方法被映射到ObjectDataSou
18、rce的Select()、Insert()、Update()和Delete()方法。圖6,至今我們應(yīng)該很熟悉,映射ObjectDataSource的Select()方法到ProductsBLL類(lèi)的GetProducts()方法。Insert()、Update()和Delete()方法可以通過(guò)選擇上方的適當(dāng)?shù)膖ab頁(yè)進(jìn)行配置。圖 6: 讓這個(gè)ObjectDataSource返回所有產(chǎn)品圖7、8和9顯示ObjectDataSource的UPDATE、INSERT,和DELETE 的tab頁(yè)。配置它們從而Insert()、Update()和Delete()方法分別調(diào)用ProductsBLL類(lèi)的Upd
19、ateProduct、AddProduct和DeleteProduct方法。圖 7: 映射ObjectDataSource的Update()方法到ProductBLL類(lèi)的UpdateProduct方法圖 8: 映射ObjectDataSource的Insert()方法到ProductBLL類(lèi)的AddProduct方法圖 9: 映射ObjectDataSource的Delete()方法到ProductBLL類(lèi)的DeleteProduct方法你也許已經(jīng)注意到在UPDATE、INSERT和DELETE的tab頁(yè)里的下拉列表中已經(jīng)選擇了各自的方法。這是由于我們使用了DataObjectMethodAt
20、tribute,它修飾了ProducstBLL類(lèi)。例如,DeleteProduct方法是如下這樣子聲明的:?123456System.ComponentModel.DataObjectMethodAttribute (System.ComponentModel.DataObjectMethodType.Delete, true)public bool DeleteProduct(int productID) .DataObjectMethodAttribute指示每一個(gè)方法的目的是否為了查詢(xún)、插入、更新或刪除是否它的默認(rèn)值。如果你在創(chuàng)建BLL類(lèi)的時(shí)候
21、省略了這些屬性,現(xiàn)在你將需要手工從UPDATE、INSERT和DELETE的tab頁(yè)里手工選擇方法。當(dāng)確認(rèn)已經(jīng)適當(dāng)?shù)腜roductsBLL方法映射到ObjectDataSource的Insert()、Update()和Delete()方法后,點(diǎn)擊完成結(jié)束此向?qū)Аz查ObjectDataSource的標(biāo)記在通過(guò)數(shù)據(jù)源配置向?qū)瓿闪藢?duì)ObjectDataSource的配置之后,到源視圖去檢查一下生成的聲明標(biāo)記。<asp:ObjectDataSource>標(biāo)簽列明了隱含的對(duì)象和需要調(diào)用的方法。另外,還有DeleteParameters、UpdateParameters和InsertPar
22、ameters ,它們映射ProductsBLL類(lèi)的AddProduct、UpdateProduct和DeleteProduct方法的輸入?yún)?shù):?12345678910111213141516171819202122232425262728293031<asp:ObjectDataSource ID="ObjectDataSource1" runat="server" DeleteMethod="DeleteProduct" InsertMethod="AddProduct"
23、 OldValuesParameterFormatString="original_0" SelectMethod="GetProducts" TypeName="ProductsBLL" UpdateMethod="UpdateProduct"> <DeleteParameters> <asp:Parameter Name="productID" Type="I
24、nt32" /> </DeleteParameters> <UpdateParameters> <asp:Parameter Name="productName" Type="String" /> <asp:Parameter Name="supplierID" Type="Int32" /> &
25、#160; <asp:Parameter Name="categoryID" Type="Int32" /> <asp:Parameter Name="quantityPerUnit" Type="String" /> <asp:Parameter Name="unitPrice" Type="Decimal" />
26、 <asp:Parameter Name="unitsInStock" Type="Int16" /> <asp:Parameter Name="unitsOnOrder" Type="Int16" /> <asp:Parameter Name="reorderLevel" Type="Int16" />
27、 <asp:Parameter Name="discontinued" Type="Boolean" /> <asp:Parameter Name="productID" Type="Int32" /> </UpdateParameters> <InsertParameters> <asp:Paramete
28、r Name="productName" Type="String" /> <asp:Parameter Name="supplierID" Type="Int32" /> <asp:Parameter Name="categoryID" Type="Int32" /> <asp:Parameter Na
29、me="quantityPerUnit" Type="String" /> <asp:Parameter Name="unitPrice" Type="Decimal" /> <asp:Parameter Name="unitsInStock" Type="Int16" /> <asp:Parameter
30、 Name="unitsOnOrder" Type="Int16" /> <asp:Parameter Name="reorderLevel" Type="Int16" /> <asp:Parameter Name="discontinued" Type="Boolean" /> </InsertParameters>&l
31、t;/asp:ObjectDataSource>ObjectDataSource包含了對(duì)應(yīng)它關(guān)聯(lián)的方法的每一個(gè)輸入?yún)?shù)的parameter,就像當(dāng)ObjectDataSource被配置為調(diào)用預(yù)期一個(gè)輸入?yún)?shù)的查詢(xún)方法(例如GetProductsByCategoryID(categoryID))時(shí)出現(xiàn)的SelectParameters一欄。正如我們馬上即將看到的,這些DeleteParameters、UpdateParameters和InsertParameters的值在調(diào)用ObjectDataSource的Insert()、Update()或Delete()方法之前自動(dòng)地通過(guò)GridVi
32、ew、DetailsView和FormView被設(shè)置。必要時(shí)這些值也可以通過(guò)編程設(shè)置,這在以后的章節(jié)里討論。使用數(shù)據(jù)源配置向?qū)?lái)配置ObjectDataSource的另一個(gè)影響是Visual Studio設(shè)置了OldValuesParameterFormatString屬性為original_0。這個(gè)屬性值用來(lái)包含數(shù)據(jù)被編輯時(shí)的原始值,它在下面兩種情況下非常有用:·如果,當(dāng)編輯一條記錄時(shí),用戶(hù)可以修改主鍵的值。在這種情況下,新的主鍵的值和原始的主鍵值都需要提供,這樣具有這個(gè)原始主鍵值的數(shù)據(jù)庫(kù)記錄才可以被找到然后才能將它的值更新。·當(dāng)使用開(kāi)放式并發(fā)。開(kāi)放式并發(fā)是為了保證同時(shí)操
33、作的用戶(hù)不至于覆蓋另一個(gè)用戶(hù)所做更改的一種技巧,這也是后面的教程中的一節(jié)(實(shí)現(xiàn)開(kāi)放式并發(fā) )。這個(gè)OldValuesParameterFormatString屬性指明了隱含對(duì)象的更新和刪除方法中對(duì)應(yīng)原始值的輸入?yún)?shù)的名稱(chēng)。我們將在探討開(kāi)發(fā)式并發(fā)的時(shí)候更詳細(xì)地討論這個(gè)屬性和它的目的。不過(guò)暫時(shí)我放下它,因?yàn)槲覀兊腂LL的方法并不需要這些原始的值因此我們刪除這個(gè)屬性,這一點(diǎn)很重要。如果讓OldValuesParameterFormatString屬性設(shè)置為除了默認(rèn)值(0)以外的其它任何的值,都將在數(shù)據(jù)Web控件嘗試調(diào)用ObjectDataSource的Update()或Delete()方法時(shí)引發(fā)一個(gè)
34、錯(cuò)誤,因?yàn)镺bjectDataSource將嘗試將這些原始值參數(shù)與UpdateParameters或DeleteParameters一起傳入。如果對(duì)此不是十分清楚,別擔(dān)心,我們將在未來(lái)的章節(jié)中研究這個(gè)屬性和它的效用。暫時(shí),一定要完全地從聲明語(yǔ)法中完全地刪除這個(gè)屬性或者將它設(shè)置為默認(rèn)值(0)。注意: 如果你只是簡(jiǎn)單地從設(shè)計(jì)視圖的屬性窗口刪除這個(gè)OldValuesParameterFormatString屬性的值,這個(gè)屬性依舊會(huì)存在于聲明語(yǔ)法中,不過(guò)被設(shè)置為一個(gè)空字符串。不幸地,這將依舊導(dǎo)致上面提到的同樣的問(wèn)題。所以,從聲明語(yǔ)法里徹底地刪除這個(gè)屬性,或者從屬性窗口將其設(shè)置為默認(rèn)值,0。第三步: 添
35、加一個(gè)數(shù)據(jù)Web服務(wù)器控件并配置它為數(shù)據(jù)更改服務(wù)一般ObjectDataSOurce被添加到頁(yè)面并配置完成,我們可以添加一個(gè)數(shù)據(jù)Web服務(wù)器控件用來(lái)顯示數(shù)據(jù)并提供一個(gè)最終用戶(hù)修改數(shù)據(jù)的途徑。我們將分別看看GridView、DetailsView和FormView,因?yàn)檫@些數(shù)據(jù)Web服務(wù)器控件在它們的數(shù)據(jù)更改功能和配置上都有所不同。正如我們將在本文剩下的部分里看到的,通過(guò)GridView、DetailsView和FormView控件添加一個(gè)非?;镜木庉嫛⒉迦牒蛣h除支持是真的非常簡(jiǎn)單,只需要勾選上一對(duì)CheckBox。現(xiàn)實(shí)中提供這樣的功能有許多微妙之處和邊緣案例,這要比僅僅點(diǎn)幾下要棘手得多。但是
36、,本教程里,只著眼于提供簡(jiǎn)單的數(shù)據(jù)修改功能。以后的章節(jié)將研究在現(xiàn)實(shí)中不容置疑地出現(xiàn)的問(wèn)題。從GridView中刪除數(shù)據(jù)首先,從工具箱拖拽一個(gè)GridView到設(shè)計(jì)器。然后,通過(guò)GridView的智能標(biāo)記中從下拉列表中選擇從而綁定ObjectDataSource到該GridView。在這里GridView的聲明標(biāo)記將是:?123456789101112131415161718192021222324252627282930313233<asp:GridView ID="GridView1" runat="server" AutoGenerateCol
37、umns="False" DataKeyNames="ProductID" DataSourceID="ObjectDataSource1"> <Columns> <asp:BoundField DataField="ProductID" HeaderText="ProductID" InsertVisible=&
38、quot;False" ReadOnly="True" SortExpression="ProductID" /> <asp:BoundField DataField="ProductName" HeaderText="ProductName" SortExpression="ProductName&
39、quot; /> <asp:BoundField DataField="SupplierID" HeaderText="SupplierID" SortExpression="SupplierID" /> <asp:BoundField DataField="CategoryID" HeaderText="Category
40、ID" SortExpression="CategoryID" /> <asp:BoundField DataField="QuantityPerUnit" HeaderText="QuantityPerUnit" SortExpression="Qu
41、antityPerUnit" /> <asp:BoundField DataField="UnitPrice" HeaderText="UnitPrice" SortExpression="UnitPrice" /> <asp:BoundField DataField="UnitsInStock" &
42、#160; HeaderText="UnitsInStock" SortExpression="UnitsInStock" /> <asp:BoundField DataField="UnitsOnOrder" HeaderText="UnitsOnOrder" SortExpression="UnitsOnOrder" />
43、160; <asp:BoundField DataField="ReorderLevel" HeaderText="ReorderLevel" SortExpression="ReorderLevel" /> <asp:CheckBoxField DataField="Discontinued"
44、0; HeaderText="Discontinued" SortExpression="Discontinued" /> <asp:BoundField DataField="CategoryName" HeaderText="CategoryName" ReadOnly="True" S
45、ortExpression="CategoryName" /> <asp:BoundField DataField="SupplierName" HeaderText="SupplierName" ReadOnly="True" SortExpression="SupplierName" />&
46、#160; </Columns></asp:GridView>通過(guò)它的職能標(biāo)記綁定GridView到ObjectDataSource有下面兩點(diǎn)的好處:·綁定列和CheckBox列被自動(dòng)地添加,對(duì)應(yīng)ObjectDataSource返回的每一個(gè)字段。而且,這些綁定列和CheckBox列的屬性已經(jīng)被設(shè)置,基于隱含字段的元數(shù)據(jù)。例如ProductID、CategoryName和SupplierName列在ProductsDataTable里被標(biāo)記為只讀,因此它們?cè)诰庉嫊r(shí)也是不可更新的。為了實(shí)現(xiàn)這一點(diǎn),這些綁定列的ReadOnly屬性設(shè)置為true 。
47、3;DataKeyNames屬性被賦值為隱含對(duì)象的主鍵。這是在使用GridView來(lái)編輯或刪除數(shù)據(jù)的要點(diǎn),因?yàn)檫@個(gè)屬性象指出了標(biāo)識(shí)唯一記錄的那個(gè)字段(或是一組字段)。如果要獲得更多的關(guān)于DataKeyNames屬性的信息,請(qǐng)回到使用GridView 和DetailView實(shí)現(xiàn)的主/從報(bào)表一節(jié)。雖然可以通過(guò)屬性窗口或者聲明語(yǔ)法將GridView綁定到ObjectDataSource,不過(guò)這需要你手工添加適當(dāng)?shù)慕壎泻虳ataKeyNames標(biāo)記。GridView控件提供了對(duì)行編輯和刪除的內(nèi)建的支持。配置一個(gè)GridView支持刪除需要添加一個(gè)刪除按鈕列。當(dāng)最終用戶(hù)點(diǎn)擊某一特定行的刪除按鈕時(shí),引發(fā)
48、一次回傳并且GridView執(zhí)行以下步驟:1.對(duì)ObjectDataSource的DeleteParameters賦值2.調(diào)用ObjectDataSource的Delete()方法,刪除指定的記錄3.通過(guò)調(diào)用它的Select()方法GridView重新綁定到ObjectDataSource賦值到DeleteParameters的值是點(diǎn)擊刪除按鈕這一行的DataKeyNames字段的值。因此正確地設(shè)置GridView的DataKeyNames屬性是至關(guān)重要的。如果缺少了這個(gè),DeleteParameters將在第1步被賦上一個(gè)null值,從而在第2步中將不會(huì)導(dǎo)致刪除任何記錄。為了給GridVie
49、w增加刪除功能,簡(jiǎn)單地到它的職能標(biāo)記里勾選上“啟用刪除”。圖 10: 勾選“啟用刪除”從智能標(biāo)記中勾選啟用刪除會(huì)添加一個(gè)CommandField到GridView。這個(gè)CommandField在GridView中補(bǔ)充一個(gè)按鈕列,它履行一個(gè)或多個(gè)下屬任務(wù):選中一行記錄、編輯一行記錄和刪除一行記錄。我們先前在使用GridView 和DetailView實(shí)現(xiàn)的主/從報(bào)表一節(jié)的教程里也看到過(guò)了CommandField用作選中記錄時(shí)如何運(yùn)作。這個(gè)CommandFIeld包含了一些ShowXButton屬性,它指示哪一系列的按鈕顯示在CommandField中。通過(guò)勾選啟用刪除,一個(gè)ShowDeleteB
50、utton屬性為true的CommandField被添加到GridView的列集合。?1234567<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="ProductID" DataSourceID="ObjectDataSource1"> <Columns> &l
51、t;asp:CommandField ShowDeleteButton="True" /> . BoundFields removed for brevity . </Columns></asp:GridView>到這里,你可能還不能相信,我們已經(jīng)完成了給這個(gè)GridView增加刪除支持!正如圖11顯示的,當(dāng)我們通過(guò)瀏覽器訪問(wèn)此頁(yè)面時(shí),一列刪除按鈕已經(jīng)出現(xiàn)。圖 11: 這個(gè)CommandField添加一列刪除按鈕如果你是從一開(kāi)始就是自己創(chuàng)建本教程的程序,當(dāng)測(cè)試這個(gè)頁(yè)面點(diǎn)擊刪除按
52、鈕時(shí)將引發(fā)一個(gè)異常。繼續(xù)讀下去學(xué)習(xí)關(guān)于為什么會(huì)引發(fā)這些異常,還有如何修復(fù)它們。注意: 如果你是跟隨著下載的教程的程序,這些問(wèn)題已經(jīng)被解決。然而,我鼓勵(lì)你從頭到尾讀一遍下面列出的詳細(xì)資料來(lái)幫助你識(shí)別可能出現(xiàn)的問(wèn)題和適宜的工作區(qū)。如果,當(dāng)嘗試刪除一個(gè)產(chǎn)品,你得到一個(gè)類(lèi)似于“ObjectDataSource 'ObjectDataSource1' could not find a non-generic method 'DeleteProduct' that has parameters: productID, original_ProductID,”的異常,你可能忘
53、記了從ObjectDataSource里刪除OldValuesParameterFormatString屬性。指定了OldValuesParameterFormatString屬性的話,該ObjectDataSource會(huì)試圖向DeleteProduct方法一并傳入productID和original_ProductID輸入?yún)?shù),然而,DeleteProduct方法只能接受一個(gè)輸入?yún)?shù),導(dǎo)致異常。刪除OldValuesParameterFormatString屬性(或設(shè)置它為0)指示ObjectDataSource不要試圖傳入這個(gè)原始值的輸入?yún)?shù)。圖 12: 確保OldValuesParame
54、terFormatString屬性已被徹底清除即使你已經(jīng)刪除了OldValuesParameterFormatString屬性,當(dāng)你嘗試刪除一個(gè)產(chǎn)品時(shí)依舊將得到一個(gè)異常:“The DELETE statement conflicted with the REFERENCE constraint 'FK_Order_Details_Products'.”。Northwind數(shù)據(jù)庫(kù)包含了一個(gè)在Order Details和Products表間的字段約束,表示如果一個(gè)產(chǎn)品在Order Details表里對(duì)應(yīng)它有一條或多條記錄,那么該產(chǎn)品不能被刪除。因?yàn)镹orthwind數(shù)據(jù)庫(kù)里的每一個(gè)
55、產(chǎn)品在Order Details表里都至少有一條記錄,所以我們不能刪除任何產(chǎn)品,除非我們從order details表里刪除這個(gè)產(chǎn)品的關(guān)聯(lián)記錄。圖 13: 一個(gè)字段間約束阻止了對(duì)產(chǎn)品的刪除為了我們的教程,就讓我們刪除Order Details表里的所有記錄吧。在一個(gè)真實(shí)的應(yīng)用程序中我們需要的是下面任一措施:·通過(guò)另外一個(gè)頁(yè)面管理order details信息·在DeleteProduct方法里增加包含刪除指定產(chǎn)品的訂單明細(xì)的邏輯·修改TableAdapter所使用的SQL語(yǔ)句,包含對(duì)指定產(chǎn)品的訂單明細(xì)的刪除就讓我們從Order Details表里刪除所有記錄從而繞
56、過(guò)字段間約束的問(wèn)題。到Visual Studio的服務(wù)器資源管理器,在NORTHWND.MDF節(jié)點(diǎn)上點(diǎn)擊鼠標(biāo)右鍵,選擇“新建查詢(xún)”。然后,再查詢(xún)窗口執(zhí)行下面的SQL語(yǔ)句:DELETE FROM Order Details圖 14: 從Order Details表里刪除所有記錄在清空了Order Details表后,點(diǎn)擊刪除按鈕將會(huì)正確無(wú)誤地刪除這個(gè)產(chǎn)品。如果點(diǎn)擊了刪除按鈕但是沒(méi)有刪除該產(chǎn)品,檢查并確保GridView的DataKeyNames屬性設(shè)置為主鍵(ProductID)。注意:當(dāng)點(diǎn)擊刪除按鈕時(shí)引發(fā)一次回傳并刪了了該記錄。這是危險(xiǎn)的,因?yàn)樗苋菀滓馔獾劐e(cuò)誤點(diǎn)擊了別的行的刪除按鈕。以后的章
57、節(jié)里我們將看看如何在刪除記錄時(shí)添加一個(gè)客戶(hù)端的確認(rèn)詢(xún)問(wèn)。在GridView中編輯數(shù)據(jù)跟刪除支持一起,GridView還提供了內(nèi)建的對(duì)行編輯的支持。配置GrdiView支持編輯將添加一列編輯按鈕。從最終用戶(hù)的角度,點(diǎn)擊一行的編輯按鈕可使這一行變成可編輯的,它的單元格轉(zhuǎn)換成文本框并包含現(xiàn)有的值,并把編輯按鈕替換成保存和取消按鈕。在完成了他們期望的更改之后,最終用戶(hù)可以點(diǎn)擊保存按鈕提交這些修改,或者點(diǎn)擊取消按鈕放棄這些修改。在任意一種情況,點(diǎn)擊保存或者取消按鈕后GridView回到它編輯前的狀態(tài)。站在我們頁(yè)面開(kāi)發(fā)者的角度,當(dāng)最終用戶(hù)點(diǎn)擊特定一行的編輯按鈕時(shí),引發(fā)一次回傳并且GridView執(zhí)行以下步
58、驟:1.GridView的EditItemIndex屬性被賦值為當(dāng)前點(diǎn)擊編輯按鈕的行的索引2.通過(guò)調(diào)用它的Select()方法,GridView重新綁定自己到ObjectDataSource3.與EditItemIndex相匹配的行呈現(xiàn)為編輯模式。在此模式下,編輯按鈕替換為保存和取消按鈕,并且那些ReadOnly屬性為False的綁定列呈現(xiàn)為T(mén)extBox服務(wù)器控件,這些TextBox的Text屬性被賦值為相應(yīng)的數(shù)據(jù)字段的值。到這里HTML標(biāo)記被返回到瀏覽器,允許最終用戶(hù)可以修改行數(shù)據(jù)。當(dāng)用戶(hù)點(diǎn)擊保存按鈕,再次發(fā)生一次回傳,并且GridView執(zhí)行以下幾個(gè)步驟:1.ObjectDataSour
59、ce的UpdateParameters的值被賦值為最終用戶(hù)在GridView的編輯界面輸入的值2.調(diào)用ObjectDataSource的Update()方法,更新指定的記錄3.通過(guò)調(diào)用它的Select()方法,GridView重新綁定自己到ObjectDataSource在DataKeyNames屬性指定的主鍵的值在第1步中賦值到UpdateParameters,反之非主鍵的值來(lái)自當(dāng)前編輯行的TextBox服務(wù)器控件。如果這一點(diǎn)遺漏了,那么UpdateParameters主鍵的值在第1步中將被賦上一個(gè)值,然后轉(zhuǎn)入第2步中將不會(huì)導(dǎo)致任何記錄的更新。編輯功能可以簡(jiǎn)單地通過(guò)勾選GridView的智能
60、標(biāo)記中的啟用編輯從而被激活。圖 15: 勾選啟用編輯勾選啟用編輯將添加一個(gè)CommandField(如果需要的話)并設(shè)置它的ShowEditButton屬性為true 。如我們之前所看過(guò)的,CommandField包含一些ShowXButton屬性,他們指出哪一系列的按鈕要顯示在CommandField里。在我們的例子里,勾選啟用編輯添加ShowEditButton屬性到現(xiàn)有的CommandField里:?12345678<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns=
61、"False" DataKeyNames="ProductID" DataSourceID="ObjectDataSource1"> <Columns> <asp:CommandField ShowDeleteButton="True" ShowEditButton="True" />
62、 . BoundFields removed for brevity . </Columns></asp:GridView>就這樣就添加了根本的編輯支持。如圖16所示,編輯界面還比較粗糙每一個(gè)非只讀的綁定列呈現(xiàn)為一個(gè)TextBox。這包括像CategoryID和SupplierID的字段,而它們是來(lái)自其它表的外鍵。圖 16: 點(diǎn)擊產(chǎn)品“Chai”的編輯按鈕讓此行顯示為“編輯模式”為了要求用戶(hù)直接編輯外鍵,這個(gè)編輯界面還缺少了以下途徑:·如果用戶(hù)輸入一個(gè)在數(shù)據(jù)庫(kù)中不存在的CategoryID或SupplierID,此更
63、新將違反一個(gè)字段間的約束,引發(fā)一個(gè)異常。·這個(gè)編輯界面不包含任何數(shù)據(jù)驗(yàn)證。如果你不提供一個(gè)必填的值(例如ProductName),或者在要求輸入數(shù)字的地方輸入一個(gè)字符串,將拋出一個(gè)異常。未來(lái)的章節(jié)里將研究如何在編輯的用戶(hù)界面中增加驗(yàn)證控件(給編輯和新增界面增加驗(yàn)證控件)。·通常,產(chǎn)品的所有非只讀字段都必須包含在GridView里。如果我們從GridView里剔除一列,比如說(shuō)UnitPrice,當(dāng)更新數(shù)據(jù)時(shí)GridView將不會(huì)設(shè)置UnitPrice UpdateParameters的值,這將把該數(shù)據(jù)庫(kù)記錄的UnitPrice值更改為NULL值。類(lèi)似地,如果一個(gè)必填的字段,例
64、如ProductName,從GridView中被剔除了,那么這個(gè)更新將失敗,并出現(xiàn)一個(gè)上文中提及過(guò)的“Column 'ProductName' does not allow nulls”異常。·這個(gè)編輯界面遺留了許多必要的格式化的問(wèn)題。UnitPrice顯示為四位小數(shù)。理想地CategoryID和SupplierID應(yīng)該包含下拉列表(DropDownList),它列出系統(tǒng)中存在的類(lèi)別和供應(yīng)商。我們不得不承認(rèn)現(xiàn)在這還有許多缺點(diǎn),但這些將在未來(lái)的章節(jié)里談及。在DetailsView中插入、編輯和刪除數(shù)據(jù)正如我們?cè)谥暗恼鹿?jié)里看過(guò)的,DetailsView控件一次只顯示一條
65、記錄,就像GridView一樣,它也允許對(duì)當(dāng)前顯示的記錄進(jìn)行編輯和刪除。不管是對(duì)最終用戶(hù)來(lái)說(shuō)從DetailsView進(jìn)行編輯和刪除的體驗(yàn),還是在ASP.NET這一面的工作流程,都跟GridView是一樣的。DetailsView和GridView不同的地方是,它還提供了內(nèi)鍵的插入支持。為了示范DetailsView的數(shù)據(jù)修改功能,首先,添加一個(gè)DetailsView控件到Basics.aspx頁(yè)面,放在現(xiàn)有的GridView的上方,并通過(guò)DetailsView的職能標(biāo)記把它綁定到現(xiàn)有的ObjectDataSource。然后,清除DetailsView的Height和Width屬性,并從它的職能
66、標(biāo)記中勾選“啟用分頁(yè)”。為了啟用編輯、插入和刪除支持,只需要簡(jiǎn)單地從它的職能標(biāo)記里勾選上“啟用插入”、“啟用編輯”和“啟用刪除”。圖 17: 配置DetailsView支持編輯、插入和刪除與GridView一樣,添加編輯、插入或刪除支持會(huì)添加一個(gè)CommandField到該DetailsView,如下聲明語(yǔ)法所示:?1234567891011121314151617181920212223242526272829303132333435<asp:DetailsView ID="DetailsView1" runat="server" AutoGen
67、erateRows="False" DataKeyNames="ProductID" DataSourceID="ObjectDataSource1" AllowPaging="True"> <Fields> <asp:BoundField DataField="ProductID" HeaderText=&quo
68、t;ProductID" InsertVisible="False" ReadOnly="True" SortExpression="ProductID" /> <asp:BoundField DataField="ProductName" HeaderText="ProductName"
69、SortExpression="ProductName" /> <asp:BoundField DataField="SupplierID" HeaderText="SupplierID" SortExpression="SupplierID" /> <asp:BoundField DataField="CategoryI
70、D" HeaderText="CategoryID" SortExpression="CategoryID" /> <asp:BoundField DataField="QuantityPerUnit" HeaderText="QuantityPerUnit"
71、160; SortExpression="QuantityPerUnit" /> <asp:BoundField DataField="UnitPrice" HeaderText="UnitPrice" SortExpression="UnitPrice" /> <asp:BoundField DataField=&quo
72、t;UnitsInStock" HeaderText="UnitsInStock" SortExpression="UnitsInStock" /> <asp:BoundField DataField="UnitsOnOrder" HeaderText="UnitsOnOrder" SortExpression
73、="UnitsOnOrder" /> <asp:BoundField DataField="ReorderLevel" HeaderText="ReorderLevel" SortExpression="ReorderLevel" /> <asp:CheckBoxField DataField="Discontinued" Heade
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 提前解除勞動(dòng)合同的賠償計(jì)算與支付方式
- 聯(lián)合經(jīng)營(yíng)協(xié)議書(shū)范本
- 證人保證書(shū)范文2024年
- 買(mǎi)賣(mài)定金合同協(xié)議書(shū)
- 2024年外墻施工分包合同范本
- 2024中國(guó)銀行信托投資公司外匯固定資產(chǎn)貸款合同
- 互聯(lián)網(wǎng)投資合作協(xié)議書(shū)怎么寫(xiě)
- 2024設(shè)備保修合同模板
- 土方設(shè)備互換協(xié)議
- 2024年二手車(chē)轉(zhuǎn)讓合同模板
- 項(xiàng)目主要施工管理人員情況
- 個(gè)人借條電子版模板
- 關(guān)于學(xué)習(xí)“國(guó)語(yǔ)普通話”發(fā)聲亮劍【三篇】
- 玻璃廠應(yīng)急預(yù)案
- 嬰幼兒游戲照料(嬰幼兒回應(yīng)性照護(hù)課件)
- 貨車(chē)進(jìn)入車(chē)間安全要求
- MAC地址-廠商對(duì)應(yīng)表
- 2022年中國(guó)出版業(yè)總體狀況分析
- BIM大賽題庫(kù)含答案
- 造紙術(shù)學(xué)習(xí)課件
- (完整版)譯林版四年級(jí)上冊(cè)Unit7單元測(cè)試
評(píng)論
0/150
提交評(píng)論