0

是否有人知道通过 OSQL 执行命令时 SQL Server 2005 的行为与使用 SQlConnection 的编程查询之间的任何细微差别?

我有一个客户端,在远程机器上有一个数据库,我可以使用 OSQL 与之交互。但是,当我尝试通过构建 sqlconnection/sqlcommand 进行类似查询时;我收到错误:

['建立与 SQL Server 的连接时发生与网络相关或特定于实例的错误。服务器未找到或无法访问。验证实例名称是否正确以及 SQL Server 是否配置为允许远程连接(提供程序:SQL 网络接口,错误:26 - 定位服务器/实例时出错)。

这是有效的 OSQL 命令:

osql -S myHost\SQLEXPRESS -U sa -q "USE [TempDB] select [Endpoint] from [Service]"

这不起作用,生成了上面的错误。

SqlConnectionStringBuilder cnBldr = new SqlConnectionStringBuilder();

cnBldr.UserID = "sa";
cnBldr.Password  = "PASSWORD";
cnBldr.DataSource = "myHost\\SQLEXPRESS";
cnBldr.InitialCatalog = "TempDB";
using (SqlConnection cn = new SqlConnection(cnBldr.ConnectionString))

using (SqlCommand cmd = new SqlCommand("select [Endpoint] from [Service]",cn))
{
   cn.Open();
   SqlDataReader rdr = cmd.ExecuteReader();
   rdr.Read();
}

在这两种情况下,我都以同一个用户身份运行(即:我以 Windows 用户身份登录,然后打开一个 cmd 窗口并执行 OSQL 命令,或者我启动一个包含上述代码片段的 Windows 应用程序。OSQL 将工作,代码片段产生上述错误。两种情况都使用'sa'帐户访问数据库。OSQL片段将提示用户输入密码。

两者之间是否存在可归因于这种行为的一些差异?我不认为这是由于连接数的问题,因为我可以在执行 osql 命令(这将起作用)和运行应用程序(生成错误消息)之间自由切换。

感谢您的任何想法。

-约翰

4

2 回答 2

2

首先不要使用TempDB,名称是tempdb,并且您的代码将在区分大小写的实例上中断。

对于连接问题,请按照SQL Network Interfaces, error: 26 - Error Locating Server/Instance Specified中的步骤操作。OSQL 使用 ODBC,而 SQLCommand 具有内置的托管 SNI 实现,因此它们之间存在差异,并且它们受制于不同的机器全局配置设置。按照链接文章中的步骤确定连接中断的位置。

于 2011-06-13T19:19:18.267 回答
0

事实证明,这两种机制之间没有区别。该应用程序的启动方式略有不同;这种差异(特别是在生成查询之前的名称解析)是导致错误消息的原因。

从这个角度来看,osql/sqlcmd 和编程查询之间没有内在的区别。

于 2011-06-14T18:28:42.453 回答