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

ASP.NET數(shù)據(jù)庫(kù)編程之Access連接失敗

  錯(cuò)誤和失敗總會(huì)不可避免地在應(yīng)用程序中出現(xiàn)。如果有人在MDB目錄之上又添加了一級(jí)新的文件夾而“更新”了服務(wù)器的目錄樹(shù),那么將會(huì)發(fā)生什么?如果MDB名稱(chēng)被更改了會(huì)怎樣?如果MDB文件被損壞又該如何呢?以上每一個(gè)問(wèn)題都將阻止對(duì)數(shù)據(jù)的成功連接并導(dǎo)致一個(gè)失敗頁(yè)面。好的編程實(shí)踐表明需要盡可能小心地對(duì)待任何失敗。

  在討論實(shí)際命令之前,我們需要了解的是AccessDataSource控件派生于SqlDataSource控件。在大多數(shù)情況下,這只是一個(gè)背景問(wèn)題。但是當(dāng)處理異常的時(shí)候,就必須使用實(shí)際上存在于(從而以之命名的)SQL數(shù)據(jù)源對(duì)象之中的對(duì)象。

  軟著陸的技術(shù)使用的代碼將在AccessDataSource控件經(jīng)歷OnSelected event時(shí)被觸發(fā)。當(dāng)GridView從數(shù)據(jù)源控件請(qǐng)求數(shù)據(jù)時(shí),這個(gè)事件將會(huì)在內(nèi)部觸發(fā)。 處理連接錯(cuò)誤的代碼就會(huì)檢查到從數(shù)據(jù)源控件傳遞過(guò)來(lái)的異常參數(shù)。AccessDataSource控件沒(méi)有關(guān)于這個(gè)參數(shù)的自己的名稱(chēng),所以只能使用名稱(chēng)SqlDataSourceStatus- EventArguments。如果異常參數(shù)為空,那么表示什么事情都沒(méi)有發(fā)生。如果異常參數(shù)有一個(gè)值,那么將檢查這個(gè)值。如果參數(shù)是OLEDB Exception類(lèi)型的,那么頁(yè)面上的警告標(biāo)簽的文本將會(huì)有提示信息。再次提醒您注意術(shù)語(yǔ)的使用。如果有一個(gè)AccessException類(lèi)型,那將更明了,可惜實(shí)際上沒(méi)有這種類(lèi)型。可以使用更加普通的OleDbException對(duì)象并以處理異常的命令結(jié)束腳本。這樣將允許GridView繼續(xù)呈現(xiàn),雖然沒(méi)有數(shù)據(jù),并防止出現(xiàn)淺褐色背景的常規(guī)ASP.NET 2.0失敗頁(yè)面。因?yàn)镚ridView沒(méi)有得到任何數(shù)據(jù),所以它將會(huì)顯示一個(gè)替換表格,表格中只有一個(gè)在其EmptyDataText屬性中顯示消息的單元格。

  如果您在進(jìn)行這些步驟中遇到困難,千萬(wàn)不要感到悲觀;下一個(gè)練習(xí)將會(huì)進(jìn)行示范。而現(xiàn)在,只需將代碼剪切并粘貼到頁(yè)面之中。在本書(shū)的后面,我將會(huì)討論如何創(chuàng)建一個(gè)用于連接失敗情況下的GridView的替換頁(yè)面以及處理錯(cuò)誤事件的詳細(xì)內(nèi)容。

  試一試#4―― 處理AccessDataSource連接失敗

  (1) 在ch02文件夾中,創(chuàng)建一個(gè)名為T(mén)IO-4-ConnectionFailure-CS.ASPx的文件。在Design視圖中,添加一個(gè)指向Northwind 的AccessDataSource控件至頁(yè)面,該控件從表中選擇了所有列。

  (2) 添加GridView用來(lái)顯示數(shù)據(jù)源控件中的信息。同樣,添加一個(gè)標(biāo)簽控件,并將其命名為“Message”。

  (3) 現(xiàn)在切換至Source視圖并對(duì)標(biāo)記作一些修改,如下突出顯示代碼所示。如果其中有<columns>標(biāo)記部分,則將其刪除。留下的代碼應(yīng)當(dāng)如下所示:

<html>
<head id="Headl" runat="server">
<title>Chapter 2 TIO #4 Connection Failure to Access in C#</title>
</head>
<body>
<h3>Chapter 2 TIO #4 Connection Failure to Access in C#</h3>
<form id="forml" runat="server">
ASP:label ID="Message" runat="server"/><br/><br/>
ASP:gridview id="GridViewl" runat="server"
datasourceid="AccessDataSourcel"
AutoGenerateColumns="true"
EmptyDataText="No data records were returned" />
ASP:AccessDataSource ID="AccessDataSourcel" Runat="server"
selectcommand="Select * From Products"
datafile="~/App_Data/Northwind.mdb"
OnSelected="AccessDataSourcel_Selected"
/>

</form>
</body></html>
  (4) 檢查頁(yè)面;在查看由Northwind售出的產(chǎn)品的時(shí)候,不應(yīng)該出現(xiàn)問(wèn)題。

  (5) 現(xiàn)在將添加代碼來(lái)處理連接問(wèn)題了。轉(zhuǎn)到頁(yè)面的頂部并進(jìn)入如下腳本。第一個(gè)示例用C#編寫(xiě),第二個(gè)示例用VB編寫(xiě)。進(jìn)入其中之一即可。

<%@ page language="C#" %>
<script runat="server">

void AccessDataSourcel_Selected(object sender, SqlDataSourceStatusEventArgs e)
{
 if (e.Exception != null)
 {
  if(e.Exception.GetType()==typeof(System.Data.OleDb.OleDbException))
  {
   Message.Text = "There was a problem opening a connection to the
   database. Please contact the system administrator for this site.";

   //Optionally set GridViewl.Visible = false;

   e.ExceptionHandled = true;
  }
 }
}

</script>
<html> ...
  以下是用VB編寫(xiě)的腳本。

<%@ Page Language="VB" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtmlll/DTD/xhtmlll.dtd">

<script runat="server">
Sub AccessDataSourcel_Selected(ByVal sender As Object, ByVal e As
SqlDataSourceStatusEventArgs)
 If (Not e.Exception Is Nothing) Then
  If TypeOf e.Exception Is System.Data.OleDb.OleDbException Then
   Message. Text = "There was a problem opening a connection to the database. Please contact the system administrator for this site."

   ' Optionally set GridViewl.Visible = false
   e.ExceptionHandled = True
  End If
 End If
End Sub

</script>
<html> ...


  (6) 保存并運(yùn)行頁(yè)面。因?yàn)槲覀儗?shí)際的連接還保持完好,所以現(xiàn)在還沒(méi)有任何問(wèn)題。關(guān)閉瀏覽器。

  (7) 現(xiàn)在將Northwind的MDB文件從/App_Data移動(dòng)至C:/Temp文件夾中,這樣連接將會(huì)失敗。或者,可以修改代碼來(lái)嘗試連接Southwind.mdb。運(yùn)行頁(yè)面并注意瀏覽器將顯示一個(gè)得體的失敗信息。

  (8) 如果移動(dòng)了Northwind.mdb,那么將其再移動(dòng)回C:/BegASPNETDb/ App_ Data文件夾中。

  示例說(shuō)明#4―― 處理AccessDataSource連接失敗

  首先,請(qǐng)回想一下AccessDataSource控件是SqlDataSource的派生物,并且使用了應(yīng)用于OLEDB數(shù)據(jù)源的一系列異常,所以當(dāng)引用了帶有SQL或者OLEDB名稱(chēng)而不是Access名稱(chēng)的對(duì)象時(shí),請(qǐng)不要驚訝。

  請(qǐng)觀察在頁(yè)面上進(jìn)行的處理連接失敗的三個(gè)修改。第一,添加了GridView數(shù)據(jù)源控件的一個(gè)屬性,該屬性在GridView沒(méi)有從數(shù)據(jù)源控件中獲得任何數(shù)據(jù)時(shí)將會(huì)顯示一條消息。第二,添加了數(shù)據(jù)源控件的一個(gè)屬性,該屬性在OnSelected事件發(fā)生時(shí)調(diào)用Data_Selected事件處理程序。請(qǐng)注意這處于DataSource事件中。雖然用戶沒(méi)有直接選擇 AccessDataSource控件(也沒(méi)有向用戶呈現(xiàn)),但是當(dāng)GridView向數(shù)據(jù)源控件請(qǐng)求數(shù)據(jù)時(shí),選擇還是在內(nèi)部發(fā)生了。第三,您編寫(xiě)了這段腳本。

  該腳本將會(huì)接收到幾個(gè)參數(shù),其中之一就是異常。這里沒(méi)有名為AccessDataSourceStatusEventArgs的對(duì)象。但是,可以獲得一個(gè)內(nèi)部派生出 Access- DataSource 的基本對(duì)象:SQL DataSource。SqlDataSource對(duì)象具有可以提交至AccessDataSource控件的狀態(tài)參數(shù)。如果沒(méi)有問(wèn)題,則異常列表為空。如果有一個(gè)異常,那么代碼將會(huì)進(jìn)行測(cè)試來(lái)查看拋出的異常是什么類(lèi)型。同樣地,也沒(méi)有像Access Exception一樣的對(duì)象。但是,AccessDataSource將異常放入更加普通的稱(chēng)為OleDb Exception的對(duì)象中。假定在這個(gè)集合中的所有異常都是由連接失敗造成的。我們的代碼將作出反應(yīng),反饋一些友好的失敗通告到名為Message的標(biāo)簽上。

  這段代碼中的最大的竅門(mén)就是始終讓對(duì)象使用了三個(gè)不同的名稱(chēng)。使用了一個(gè)Access文件(MDB)作為數(shù)據(jù)源并使用AccessDataSource控件。但是使用了底層的SqlDataSource作為事件參數(shù)。最后,使用了普通的OLEDB異常集。很多錯(cuò)誤都源于在所有的情況下都使用名為Access的ASP.NET 2.0對(duì)象。

 

AspNet技術(shù)ASP.NET數(shù)據(jù)庫(kù)編程之Access連接失敗,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产日韩高清一区二区三区 | 尹人久久大香找蕉综合影院 | 国产亚洲欧美ai在线看片 | 16女下面流水不遮图免费观看 | 99er久久国产精品在线 | 亚洲天堂999| 草莓国产视频免费观看 | 超碰97免费人妻 | 国产对白精品刺激一区二区 | 久久久久国产一级毛片高清片 | 无码日韩人妻精品久久蜜桃免费 | 亚洲欧洲日本天天堂在线观看 | 国产精品久久久久久亚洲毛片 | 国产欧美精品一区二区三区-老狼 | 亚洲理论在线a中文字幕 | 国产无遮挡无码视频在线观看不卡 | 久久青草免费91线频观看站街 | 色婷婷亚洲精品天天综合影院 | 99视频在线免费看 | 忘忧草在线社区WWW日本直播 | 久久视频这里只精品6国产 久久视频在线视频观品15 | 黑人猛挺进小莹的体内视频 | 2019精品国产品在线不卡 | 亚洲综合AV在线在线播放 | 男人女人边摸边吃奶边做 | 亚洲性爱城 | 亚洲AV无码乱码国产精品品麻豆 | 国产成人免费不卡在线观看 | 小寡妇水真多好紧 | 久久久久国产精品嫩草影院 | 国产成人亚洲精品老王 | 亚洲欧美成人无码久久久 | 亚洲三级视频 | 两个奶被男人揉了一个晚上 | 天堂Av亚洲欧美日韩国产综合 | 天美传媒在线观看免费完整版 | 亚洲精品色婷婷在线蜜芽 | 超碰在线线公开免费视频 | 污污内射久久一区二区欧美日韩 | 亚洲欧美一区二区三区久久 | G国产精品无马 |