这不是连接超时,因为与数据库的连接正常。问题是我正在调用的存储过程花费的时间超过 30 秒并导致超时。
函数的代码看起来像这样:
SqlDatabase db = new SqlDatabase(connectionManager.SqlConnection.ConnectionString);
return db.ExecuteScalar(Enum.GetName(typeof(StoredProcs), storedProc), parameterValues);
ExecuteScalar 调用超时。如何延长此功能的超时时间?
对于快速存储过程,它工作正常。但是,其中一个函数需要一段时间,调用失败。当以这种方式调用 ExecuteScalar 函数时,我似乎找不到任何方法来延长超时时间。
最佳答案
如果您正在使用 EnterpriseLibrary(看起来您确实在使用),请尝试以下操作:
Microsoft.Practices.EnterpriseLibrary.Data.Database db = Microsoft.Practices.EnterpriseLibrary.Data.DatabaseFactory.CreateDatabase("ConnectionString");
System.Data.Common.DbCommand cmd = db.GetStoredProcCommand("StoredProcedureName");
cmd.CommandTimeout = 600;
db.AddInParameter(cmd, "ParameterName", DbType.String, "Value");
// Added to handle paramValues array conversion
foreach (System.Data.SqlClient.SqlParameter param in parameterValues)
{
db.AddInParameter(cmd, param.ParameterName, param.SqlDbType, param.Value);
}
return cmd.ExecuteScalar();
编辑为直接根据评论处理 paramValues 数组。我还包含了您的 ConnectionString 值:
Microsoft.Practices.EnterpriseLibrary.Data.Database db = Microsoft.Practices.EnterpriseLibrary.Data.DatabaseFactory.CreateDatabase(connectionManager.SqlConnection.ConnectionString);
System.Data.Common.DbCommand cmd = db.GetStoredProcCommand("StoredProcedureName", parameterValues);
cmd.CommandTimeout = 600;
return cmd.ExecuteScalar();
关于c# - 如何延长 SQL 查询的超时时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1111837/