出错提示:[DBNETLIB][ConnectionOpen (Connect()).]SQL Server 不存在或拒绝访问。 
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.Data.OleDb.OleDbException: [DBNETLIB][ConnectionOpen (Connect()).]SQL Server 不存在或拒绝访问。源代码:
<%@ Page Language="vb" ContentType="text/html" ResponseEncoding="gb2312" CodeBehind="test2.aspx.vb" Inherits="pf_web.test2" AutoEventWireup="false" %>
<%@ Import Namespace="System.Data.oledb" %>
<%@ Import Namespace="System.Data" %>
<HTML>
<HEAD>
<title>无标题文档</title>
<script language="vb" runat="server">
Dim myConnection As oledbConnection 
Dim myCommand As oledbCommand 
Dim mydtadp As oledbDataAdapter 
Dim myds As New DataSet 
Dim strSql As String 
Dim ConnStr As String
    Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs)
        '在此处放置初始化页的用户代码
strSql = "SELECT * FROM acnt" 
ConnStr="Provider=sqloledb;Data Source=22.140.192.33,1433;Network Library=DBMSSOCN;Initial Catalog=jsdata;User ID=sa;Password=zsldf;" 
myConnection = New oledbConnection(ConnStr) 
myConnection.Open() 
mydtadp = New oledbDataAdapter(strSql,myConnection) 
mydtadp.Fill(myds, "a") 
DataGrid1.CurrentPageIndex=1
DataGrid1.DataSource = myds
DataGrid1.databind()     End Sub
    Sub g_Page(ByVal source As Object, ByVal e As System.Web.UI.WebControls.DataGridPageChangedEventArgs) Handles DataGrid1.PageIndexChanged
if DataGrid1.CurrentPageIndex>=0 then
DataGrid1.CurrentPageIndex=e.NewPageIndex
else 
DataGrid1.CurrentPageIndex=0
end if
DataGrid1.databind() 
    End Sub
</script>
<META http-equiv="Content-Type" content="text/html; charset=gb2312">
</HEAD>
<BODY>
'设置连接串...
<form runat="server">
<asp:datagrid id="DataGrid1" runat="server" OnPageIndexChanged="g_Page" PagerStyle-HorizontalAlign="Right" PagerStyle-NextPageText="后页" PagerStyle-PrevPageText="前页" AllowPaging="True" AlternatingItemStyle-BackColor="#eeeeee" HeaderStyle-BackColor="#aaaadd" BorderColor="#3366CC" BorderStyle="None" BorderWidth="1px" BackColor="White" CellPadding="4">
<SelectedItemStyle Font-Bold="True" ForeColor="#CCFF99" BackColor="#009999"></SelectedItemStyle>
<ItemStyle ForeColor="#003399" BackColor="White"></ItemStyle>
<HeaderStyle Font-Bold="True" ForeColor="#CCCCFF" BackColor="#003399"></HeaderStyle>
<FooterStyle ForeColor="#003399" BackColor="#99CCCC"></FooterStyle>
<PagerStyle NextPageText="后页" PrevPageText="前页" HorizontalAlign="Left" ForeColor="#003399" BackColor="#99CCCC" Mode="NumericPages"></PagerStyle>
</asp:datagrid></form>
</BODY>
</HTML>web.config代码:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    
  <system.web>    <!--  动态调试编译
          设置 compilation debug="true" 以将调试符号(.pdb 信息)
          插入到编译页中。因为这将创建执行起来
          较慢的大文件,所以应该只在调试时将该值设置为 true,而所有其他时候都设置为
          false。有关更多信息,请参考有关
          调试 ASP.NET 文件的文档。
    -->
    <compilation defaultLanguage="vb" debug="true" />    <!--  自定义错误信息
          设置 customErrors mode="On" 或 "RemoteOnly" 以启用自定义错误信息,或设置为 "Off" 以禁用自定义错误信息。
          为每个要处理的错误添加 <error> 标记。
    -->
<customErrors mode="Off"/>
    <!--  身份验证 
          此节设置应用程序的身份验证策略。可能的模式是“Windows”、
          “Forms”、“Passport”和“None”
    -->
    
    <authentication mode="Windows" /> 
    <!--  授权 
          此节设置应用程序的授权策略。可以允许或拒绝用户或角色访问
          应用程序资源。通配符:"*" 表示任何人,"?" 表示匿名 
          (未授权的)用户。
    -->
    <authorization>
        <allow users="*" /> <!-- 允许所有用户 -->            <!--  <allow     users="[逗号分隔的用户列表]"
                             roles="[逗号分隔的角色列表]"/>
                  <deny      users="[逗号分隔的用户列表]"
                             roles="[逗号分隔的角色列表]"/>
            -->
    </authorization>    <!--  应用程序级别跟踪记录
          应用程序级别跟踪在应用程序内为每一页启用跟踪日志输出。
          设置 trace enabled="true" 以启用应用程序跟踪记录。如果 pageOutput="true",则
          跟踪信息将显示在每一页的底部。否则,可以通过从 Web 应用程序
          根浏览 "trace.axd" 页来查看 
          应用程序跟踪日志。
    -->
    <trace enabled="false" requestLimit="10" pageOutput="false" traceMode="SortByTime" localOnly="true" />
    <!--  会话状态设置
          默认情况下,ASP.NET 使用 cookie 标识哪些请求属于特定的会话。
          如果 cookie 不可用,则可以通过将会话标识符添加到 URL 来跟踪会话。
         若要禁用 cookie,请设置 sessionState cookieless="true"。
    -->
    <sessionState 
            mode="InProc"
            stateConnectionString="tcpip=127.0.0.1:42424"
            sqlConnectionString="data source=127.0.0.1;user id=sa;password="
            cookieless="false" 
            timeout="20" 
    />    <!--  全球化
          此节设置应用程序的全球化设置。
    -->
    <globalization requestEncoding="utf-8" responseEncoding="utf-8" />
   
  </system.web></configuration>

解决方案 »

  1.   

    连接地址是否正确
    服务器和端口是否开启
    防火墙是否开启
    Data Source=IP,1433;Network Library=DBMSSOCN;Initial Catalog=pubs;User ID=sa;Password=sa;
    参考
      

  2.   

    sqlserver2000 的 SP3 SP4的 补丁 需要 打好
      

  3.   

    asp.net夜话之七:ADO.NET介绍
    ADO.NET是对Microsoft ActiveX Data Objects (ADO)一个跨时代的改进,它提供了平台互用性和可伸缩的数据访问。由于传送的数据都是XML格式的,因此任何能够读取XML格式的应用程序都可以进行数据处理。事实上,接受数据的组件不一定要是ADO .NET组件,它可以是基于一个Microsoft Visual Studio的解决方案,也可以是任何运行在其它平台上的任何应用程序。以前做数据库访问的时候,需要一直与数据库保持连接,直到获取完所有满足需要的数据之后才会断开数据库连接,这种数据库访问方式称之为连接式数据访问技术。相比于以前的连接式数据访问技术,ADO.NET除了提供连接式数据访问技术之外,还提供了另一种断开式解决方案,那就是在内存中模拟一个数据库,也就是内存中的数据库。我们知道在实际的数据库技术中,每个数据库就是一个业务逻辑单元,一般来说这个数据库包含了实现一个应用软件或者一个网站所需要的全部数据。
    本篇中还讲述了自定义分页在数据库层的理论。
      

  4.   

    局域网中有哪些SQL Server数据库可以连接。连接到数据库可以用下面的方式:
    (1)如果要连接的数据库服务器与开发者的机器在同一个局域网里,可以使用局域网IP地址或者局域网中的电脑主机名;
    (2)如果要连接的数据库服务器与开发者的机器不在同一个局域网内,那么就要求数据库服务器必须有一个公网IP,我们可以使用公网IP来连接,如果数据库服务器还有互联网域名,那么用互联网域名也是可以的。
    (3)如果要连接的数据库服务器与开发者所使用的机器是同一台机器,那么可以使用以下几种方式之一:”(local)”或者”.”或者”127.0.0.1”。
    需要注意的是,如果在一台机器上运行者同一种数据库的不同版本,比如说在”zhoufoxcn”这台主机上同时运行着SQL 2000、SQL 2005和SQL Express三种版本,并且它们所使用的Windows服务名分别为”SQL2000”、”SQL2005”和”SQLExpress”,那么我们要连接到SQL 2000这个数据库上所使用的服务器名就应该填写”zhoufoxcn\SQL2000”这种“主机名\实例名”的方式或者“主机IP\实例名”,这种情况在同时安装了Visual Studio 2005和SQL 2005的朋友那里很常见,因为SQL Express是针对学生的功能有限的免费版本,这个版本的数据库在安装Visual Studio 2005时默认是一同安装的。
    另外,连接到SQL Server数据库尽量不要使用OleDbConnection,因为没有办法使用SQL Server的一些先进特性。
      

  5.   

     sqlConnectionString="data source=127.0.0.1;user id=sa;password=" password=   空吗?
      

  6.   

    你的SQlServer有没有启用TCPIP协议
      

  7.   

    检查一下你的SQL 服务器。用户名,密码。端口,防火墙。补丁 好多原因的。对代码你还要看一下。
    说不定你自己把单引号全角半角弄错了。这种问题。主要是大家提醒你。还是要你自己去查查才知道的。