我正在开发一个从 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 服务器的本地项目文件中。但我们似乎无法确切地弄清楚究竟是什么导致了时间上的差异。
任何人都对为什么存在这种差异有任何想法,或者可以给我建议在哪里寻找隔离问题?