当您试图连接到或已安装在安装 SQL Server 2005 之后的 SQL Server 7.0 SQL Server 2000 的实例时,您可能会收到一条连接的错误消息

文章翻译 文章翻译
文章编号: 905618 - 查看本文应用于的产品
展开全部 | 关闭全部

本文内容

症状

如果满足下列条件,则您可能会收到一条连接的错误消息:
  • 在安装 SQL Server 2005 后安装了 Microsoft SQL Server 2000 或 SQL Server 7.0。
  • 您尝试连接到由 SQL Server 2000 或 SQL Server 7.0 创建的实例。
此问题发生如果连接字符串不包括协议特定的信息,即使 SQL Server 浏览器服务仍在运行。

在这种情况下特定于协议的信息取决于服务器返回的信息。例如对于您可能会收到以下错误消息,当您通过使用 Sqlcmd 实用程序连接到实例 (Sqlcmd.exe):
SQL 网络接口: 错误定位服务器/实例指定 [xFFFFFFFF]。
Sqlcmd: 错误: Microsoft SQL 本机客户端: 客户端无法建立连接。
Sqlcmd: 错误: Microsoft SQL 本机客户端: 登录超时过期。

原因

当试图连接到或 SQL Server 7.0 SQL Server 2000 的实例时 SQL Server 浏览器服务 (Sqlbrowser) 将尝试从 Windows 注册表,以向客户端中继获得所需的协议信息。 因此,SQL Server 浏览器服务必须有足够的权限来读取相应的 Windows 注册表,该实例。

当您设置 SQL Server 2005 时,所有的现有实例注册表项将被修改,以启用 $ SQL Server 浏览器服务读取所需的协议的信息。但是,如果您设置 SQL Server 2005 后安装了实例或 SQL Server 7.0 的 SQL Server 2000,不是设置正确的注册表权限。安装 SQL Server 浏览器服务时,会只修改权限。专门,如果 SQL Server 浏览器服务的启动帐户不是管理员帐户,该帐户可能没有所需的访问权限的权限读取的该实例相关的键。

注意在 SQL Server 2000 SQL Server 服务标识服务器连接终结点。SQL Server 2005 SQL Server 浏览器服务以替换该函数。如果您还运行 SQL Server 2000 的计算机上安装 SQL Server 2005,您必须在该计算机上安装 SQL Server 2000 Service Pack 3 (SP3)、 SQL Server 2000 SP3a,或 SQL Server 2000 SP4。

替代方法

重要此分区、 方法,或任务包含告诉您如何修改注册表的步骤。但是,如果注册表修改不当可能会出现严重问题。因此,请确保您仔细按照这些步骤。附加的保护注册表之前先备份您对其进行修改。然后,您可以在出现问题时还原注册表。有关如何备份和还原注册表的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
322756如何备份和还原在 Windows 注册表
可以使用下列方法之一解决此问题。

修改注册表以授予读取的权限的特定键

为您安装的 SQL Server 2000 的每个实例后,您安装了 SQL Server 2005,请按照下列步骤:
  1. 单击 开始、 单击 运行,键入 regedit,然后单击 确定
  2. 找到以下注册表子项:
    HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\InstanceName
    在此子项,InstanceName 是实例的 SQL Server 2000 的名称。

    注意如果您作为默认实例安装 SQL Server 2000,注册表子项是下列:
    HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\MSSQLServer
  3. 编辑 菜单上单击 权限
  4. 单击 添加,键入 SQLServer2005SQLBrowserUser 或键入 SQLServer2005SQLBrowserUser $ ComputerName,然后单击 确定

    注意您的计算机上帐户的组名 SQLServer2005SQLBrowserUser 可能 SQLServer2005SQLBrowserUser $ 计算机名。您可以在 本地用户和组计算机管理中 找到此组的名称。在这一步中 SQLServer2005SQLBrowserUser $ 计算机名计算机名 是计算机的您的名称。
  5. 单击以选中此用户帐户权限列表中的 读取 复选框,然后单击 确定
  6. 退出注册表编辑器,然后重新启动 SQL Server 浏览器服务。
注意应由子键中继承权限。如果权限不会继承,您必须明确地授予读取的权限 SQLServer2005SQLBrowserUserSQLServer2005SQLBrowserUser $ 计算机名 的下面的项如果它们存在执行以下操作:
  • HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\<InstanceName>\CurrentVersion
  • HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\<InstanceName>\SuperSocketNetLib
  • HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\<InstanceName>\Cluster
注意在此子项,InstanceName 是实例的 SQL Server 2000 的名称。

如果
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\<InstanceName>\SuperSocketNetLib
注册表子项不被继承,您必须手动修改此注册表子项为基础的键。

注意SQL Server 7.0 没有命名的实例。因此,相关的注册表项应具有适当的权限从继承
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\MSSQLServer
注册表子项。但是,如果有不被继承了权限您必须手动设置了权限。

显式指定连接字符串中的连接信息

当从客户端连接到实例或 SQL Server 7.0 的 SQL Server 2000 时,您将可以在连接字符串中显式指定连接信息。您指定此信息,以便将连接信息并不依赖于服务器所返回的信息。例如对于您可以通过连接到该实例使用的类似于下面的命令命令,当您使用该 Sqlcmd 实用程序。
sqlcmd –S tcp:yourhost,1500

状态

Microsoft 已经确认这是在"适用于"一节中列出的 Microsoft 产品中的问题。

属性

文章编号: 905618 - 最后修改: 2006年3月10日 - 修订: 3.4
这篇文章中的信息适用于:
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL 2005 Server Enterprise
  • Microsoft SQL Server 2005 Express Edition
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL 2005 Server Workgroup
关键字:?
kbmt kbtshoot kberrmsg kbprb KB905618 KbMtzh
机器翻译
注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。
点击这里察看该文章的英文版: 905618
Microsoft和/或其各供应商对于为任何目的而在本服务器上发布的文件及有关图形所含信息的适用性,不作任何声明。 所有该等文件及有关图形均"依样"提供,而不带任何性质的保证。Microsoft和/或其各供应商特此声明,对所有与该等信息有关的保证和条件不负任何责任,该等保证和条件包括关于适销性、符合特定用途、所有权和非侵权的所有默示保证和条件。在任何情况下,在由于使用或运行本服务器上的信息所引起的或与该等使用或运行有关的诉讼中,Microsoft和/或其各供应商就因丧失使用、数据或利润所导致的任何特别的、间接的、衍生性的损害或任何因使用而丧失所导致的之损害、数据或利润不负任何责任。

提供反馈

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com