使用osql和sqlcommand时SQLServer 2005的行为差异

时间:2011-06-13 17:08:12

标签: sql-server sql-server-2005 osql

是否有人知道通过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命令(将工作)和运行应用程序(生成错误消息)之间自由切换。

感谢您的任何想法。

-John

2 个答案:

答案 0 :(得分:2)

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

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

答案 1 :(得分:0)

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

从这个角度来看,osql / sqlcmd和程序化查询之间没有固有的区别。