1

我正在开发一个从 MSSQL 服务器读取数据的团队项目。我们正在使用异步调用来获取数据。

SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString);
SqlCommand cmdData = new SqlCommand("get_report", conn);
cmdData.CommandType = CommandType.StoredProcedure;

conn.Open();
IAsyncResult asyResult = cmdData.BeginExecuteReader();

try
{
    SqlDataReader drResult = cmdData.EndExecuteReader(asyResult);
    table.Load(drResult);
}
catch (SqlException ex)
{
    throw;
}

该项目本身使用带有门控签入的 TFS 源代码控制,并且我们已经验证两台计算机都在运行完全相同的项目版本。我们还使用相同的用户登录名并使用完全相同的参数执行存储过程(为简洁起见,未列出)。

存储过程本身需要 1:54 在 SQL Server Management Studio 下返回 42000 行。在 Windows 7 x86 上运行时,.NET 代码的执行时间与在 SSMS 上的执行时间大致相同,并且上面的代码片段可以完美执行。EndExecuteReader但是,在我运行 Windows 7 x64 的计算机上,上面的代码在 0:40 标记处遇到错误。返回的错误是“无效操作。连接已关闭。”

添加cmdData.CommandTimeout = 600允许执行继续,但数据需要超过 4 分钟才能返回,我们无法解释可能发生的情况。

我们考虑了一些事情:我的计算机安装了 .NET 4.5 Framework,正在针对 32 位程序集运行 64 位操作系统,可能将信息存储在未同步到 TFS 服务器的本地项目文件中。但我们似乎无法确切地弄清楚究竟是什么导致了时间上的差异。

任何人都对为什么存在这种差异有任何想法,或者可以给我建议在哪里寻找隔离问题?

4

1 回答 1

0

当为单个命令执行多次调用 EndExecuteReader 或该方法与其执行方法不匹配时,将收到 Invalid Operation 错误。

于 2012-05-16T14:50:44.560 回答