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

如何解决使用osql和sqlcommand时SQLServer 2005的行为差异

|| 是否有人知道通过OSQL执行命令与使用SQlConnection进行编程查询时SQL Server 2005行为之间的细微差别? 我有一个客户端,该客户端的远程计算机上可以使用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命令(将起作用)和运行应用程序(生成错误消息)之间自由切换。 感谢您的任何想法。 -约翰     

解决方法

        首先不要使用
TempDB
,名称是
tempdb
,您的代码将在区分大小写的实例上中断。 对于连接问题,请遵循SQL网络接口中的步骤,错误:26-错误指定服务器/实例。 OSQL使用ODBC,而SQLCommand具有内置的托管SNI实现,因此它们之间存在差异,并且它们受不同的计算机全局配置设置的影响。请按照链接的文章中的步骤确定连接断开的位置。     ,        事实证明,这两种机制之间没有区别。该应用程序的启动略有不同;而这种差异(特别是生成查询之前的名称解析)是导致错误消息的原因。 从这个角度来看,osql / sqlcmd和程序化查询之间没有固有的区别。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?