ASP.NET数据库编程之Access连接失败

  错误和失败总会不可避免地在应用程序中出现。如果有人在MDB目录之上又添加了一级新的文件夹而“更新”了服务器的目录树,那么将会发生什么?如果MDB名称被更改了会怎样?如果MDB文件被损坏又该如何呢?以上每一个问题都将阻止对数据的成功连接并导致一个失败页面。好的编程实践表明需要尽可能小心地对待任何失败。

  在讨论实际命令之前,我们需要了解的是AccessDataSource控件派生于SqlDataSource控件。在大多数情况下,这只是一个背景问题。但是当处理异常的时候,就必须使用实际上存在于(从而以之命名的)SQL数据源对象之中的对象。

  软着陆的技术使用的代码将在AccessDataSource控件经历OnSelected event时被触发。当GridView从数据源控件请求数据时,这个事件将会在内部触发。 处理连接错误的代码就会检查到从数据源控件传递过来的异常参数。AccessDataSource控件没有关于这个参数的自己的名称,所以只能使用名称SqlDataSourceStatus- EventArguments。如果异常参数为空,那么表示什么事情都没有发生。如果异常参数有一个值,那么将检查这个值。如果参数是OLEDB Exception类型的,那么页面上的警告标签的文本将会有提示信息。再次提醒您注意术语的使用。如果有一个AccessException类型,那将更明了,可惜实际上没有这种类型。可以使用更加普通的OleDbException对象并以处理异常的命令结束脚本。这样将允许GridView继续呈现,虽然没有数据,并防止出现浅褐色背景的常规ASP.NET 2.0失败页面。因为GridView没有得到任何数据,所以它将会显示一个替换表格,表格中只有一个在其EmptyDataText属性中显示消息的单元格。

  如果您在进行这些步骤中遇到困难,千万不要感到悲观;下一个练习将会进行示范。而现在,只需将代码剪切并粘贴到页面之中。在本书的后面,我将会讨论如何创建一个用于连接失败情况下的GridView的替换页面以及处理错误事件的详细内容。

  试一试#4—— 处理AccessDataSource连接失败

  (1) 在ch02文件夹中,创建一个名为TIO-4-ConnectionFailure-CS.aspx的文件。在Design视图中,添加一个指向Northwind 的AccessDataSource控件至页面,该控件从表中选择了所有列。

  (2) 添加GridView用来显示数据源控件中的信息。同样,添加一个标签控件,并将其命名为“Message”。

  (3) 现在切换至Source视图并对标记作一些修改,如下突出显示代码所示。如果其中有<columns>标记部分,则将其删除。留下的代码应当如下所示:

<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) 检查页面;在查看由Northwind售出的产品的时候,不应该出现问题。

  (5) 现在将添加代码来处理连接问题了。转到页面的顶部并进入如下脚本。第一个示例用C#编写,第二个示例用VB编写。进入其中之一即可。

<%@ 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编写的脚本。

<%@ 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) 保存并运行页面。因为我们实际的连接还保持完好,所以现在还没有任何问题。关闭浏览器。

  (7) 现在将Northwind的MDB文件从\App_Data移动至C:\Temp文件夹中,这样连接将会失败。或者,可以修改代码来尝试连接Southwind.mdb。运行页面并注意浏览器将显示一个得体的失败信息。

  (8) 如果移动了Northwind.mdb,那么将其再移动回C:\BegAspNetDb\ App_ Data文件夹中。

  示例说明#4—— 处理AccessDataSource连接失败

  首先,请回想一下AccessDataSource控件是SqlDataSource的派生物,并且使用了应用于OLEDB数据源的一系列异常,所以当引用了带有SQL或者OLEDB名称而不是Access名称的对象时,请不要惊讶。

  请观察在页面上进行的处理连接失败的三个修改。第一,添加了GridView数据源控件的一个属性,该属性在GridView没有从数据源控件中获得任何数据时将会显示一条消息。第二,添加了数据源控件的一个属性,该属性在OnSelected事件发生时调用Data_Selected事件处理程序。请注意这处于DataSource事件中。虽然用户没有直接选择 AccessDataSource控件(也没有向用户呈现),但是当GridView向数据源控件请求数据时,选择还是在内部发生了。第三,您编写了这段脚本。

  该脚本将会接收到几个参数,其中之一就是异常。这里没有名为AccessDataSourceStatusEventArgs的对象。但是,可以获得一个内部派生出 Access- DataSource 的基本对象:SQL DataSource。SqlDataSource对象具有可以提交至AccessDataSource控件的状态参数。如果没有问题,则异常列表为空。如果有一个异常,那么代码将会进行测试来查看抛出的异常是什么类型。同样地,也没有像Access Exception一样的对象。但是,AccessDataSource将异常放入更加普通的称为OleDb Exception的对象中。假定在这个集合中的所有异常都是由连接失败造成的。我们的代码将作出反应,反馈一些友好的失败通告到名为Message的标签上。

  这段代码中的最大的窍门就是始终让对象使用了三个不同的名称。使用了一个Access文件(MDB)作为数据源并使用AccessDataSource控件。但是使用了底层的SqlDataSource作为事件参数。最后,使用了普通的OLEDB异常集。很多错误都源于在所有的情况下都使用名为Access的ASP.NET 2.0对象。

(0)

相关推荐

  • ASP.NET连接SQL数据库的简单实例代码

    复制代码 代码如下: using System;using System.Collections;using System.ComponentModel;using System.Data;using System.Drawing;using System.Web;using System.Web.SessionState;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.HTMLControls;us

  • ASP.NET 6种常用数据库的连接方法

    1.C#连接连接Access 程序代码:     复制代码 代码如下: using   System.Data; using   System.Data.OleDb;    .. string   strConnection="Provider=Microsoft.Jet.OleDb.4.0;";     strConnection+=@"Data   Source=C:BegASPNETNorthwind.mdb"; OleDbConnection   objCo

  • ASP.NET连接sql2008数据库的实现代码

    利用SqlConnection对象连接sql2000以上版本,并使用SqlCommand对象对数据库进行读取. SqlCommand类概述: 用于对sql数据库执行sql语句或存储过程. 命名空间:System.Data.SqlClient 程序集: System.Data(在 System.Data.dll中) SqlCommand类的属性 1.CommandText 获取或设置要对数据源执行的Transact-SQL语句或存储过程. 2. CommandType 获取或设置一个值,该值指示如

  • asp.net快速连接access

    大家都等着急了吧,直接上方法 1.确定asp.net的文档头部语句:<%@ Page Language="C#" %> 2.引用数据库语句: <%@ import Namespace="System.Data" %> <%@ import Namespace="System.Data.OleDb" %> 3.建立一个数据库:data.mdb 4.js代码script语句的编写: <script runat

  • ASP.NET oledb连接Access数据库的方法

    使用OleDBCommand相关操作类需要引入System.Data.OleDb命名空间. 通过连接一个带密码的access数据库 读取其中的数据并置入表格中显示,验证连接和命令使用正确性. using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; using System.Da

  • 在ASP.NET中连接SQL Server的简单方法

    首先导入名字空间:System.Data和System.Data.SqlClient.详细代码看源程序. 复制代码 代码如下: <%@ Import Namespace="System.Data" %><%@ Import Namespace="System.Data.SqlClient" %><html><script language="C#" runat="server">

  • ASP.NET连接MySql数据库的2个方法及示例

    方法一: 使用MySQL官方组件使用MySQL推出的 MySQL Connector/Net 组件, 该组件是MySQL为ADO.NET访问MySQL数据库设计的.NET专用访问组件.完成该组件后,需要在项目中引用这个组件,也可以直接在配置文件的< assemblies>节点内添加下面的节点: 复制代码 代码如下: <add assembly="MySql.Data, Version=5.1.5.0, Culture=neutral, PublicKeyToken=C5687F

  • asp.net通过配置文件连接Access的方法

    本文实例讲述了asp.net通过配置文件连接Access的方法.分享给大家供大家参考.具体分析如下: 这里数据库blog.mdb存放在App_Data中 配置文件 <connectionStrings> //方法一 <add name="access_conn" connectionString="Provider=Microsoft.Jet.Oledb.4.0;data source="/> <add name="acces

  • ASP.NET中操作SQL数据库(连接字符串的配置及获取)

    在WebConfig中配置数据库连接字符串,代码如下: 复制代码 代码如下: <connectionStrings> <add name="ConnectionString" connectionString="user id=用户名;password=密码;initial catalog=数据库名称;data source=服务器名称"/> </connectionStrings> 然后在Webform_1.aspx.cs里面获

  • asp.NET连接数的设置方法

    做压力测试或服务端请求一个特定域名时,同一时刻的连接量默认被.NET框架限制了,需要设置才能生效,我是通过windows的性能计数查看到压力测试一直没有真正提交上来,才发现这个问题,主要的设置参数为:System.Net.ServicePointManager.DefaultConnectionLimit,需要设置的相关参数如下: System.Net.ServicePointManager.DefaultConnectionLimit在windows程序时默认为2,不设置值,有可能会更大一点,

  • ASP.NET 连接ACCESS数据库的简单方法

    index.aspx 复制代码 代码如下: <%@ Page Language="C#" %><%@ import Namespace="System.Data" %><%@ import Namespace="System.Data.OleDb" %><script runat="server">    // Insert page code here    //    voi

  • asp.net程序优化 尽量减少数据库连接操作

    项目以我自己的设计编码完成,并整合测试.初始化数据时,问题出现了.刚开始体现在客户端接受数据很慢.测试环境环境下,数据库服务器部署在国外,网站部署在公司内部,而且我一直认为我的程序在数据库数据处理这里已经做了足够的优化,包括索引和主键已经做到了合理使用.综上所述,起初的速度问题一直没有引起我的关注. 然而最后问题的关键恰恰出在数据库连接查询方面,频繁查询导致数据初始化速度很慢.刚开始我采取的方法是即用即查:需要数据的时候就从数据库查,有比较多的单表查询返回单个字段的情况.假如我有大概3000条左

随机推荐