我有使用EF Core的ASP.NET Core 2.2应用程序。在startup.cs中,我将CommandTimeout
设置为60秒
services.AddDbContext<CrowdReason.WMP.Data.Entities.WMPContext>(options =>
options.UseSqlServer(configuration.getconnectionString("DefaultConnection"),sqlServerOptions => sqlServerOptions.CommandTimeout(60)));
然后我正在使用以下代码执行存储的proc。请注意注释中的t1
,t2
和t3
的值
public static async Task<int?> prcDoWork(this WMPContext dbContext,int id,int userID)
{
var t1 = dbContext.Database.getcommandTimeout();
// t1 is 60. Same as what i set in startup.cs
using (var connection = dbContext.Database.GetDbConnection())
{
var t2 = connection.ConnectionTimeout;
//t2 is 15
using (var cmd = connection.CreateCommand())
{
var p1 = new SqlParameter("@ID",SqlDbType.Int)
{
Value = id
};
var p2 = new SqlParameter("@UserID",SqlDbType.Int)
{
Value = userID
};
cmd.CommandText = "dbo.prcDoWork";
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add(p1);
cmd.Parameters.Add(p2);
var t3 = cmd.CommandTimeout;
//t3 is 30
await dbContext.Database.OpenConnectionAsync().ConfigureAwait(false);
var result = await cmd.ExecuteScalarAsync().ConfigureAwait(false);
if (result != null)
{
return Convert.ToInt32(result);
}
return null;
}
}
}
我知道ConnectionTimeout
与CommandTimeout
不同。
但是问题是,当我使用connection.CreateCommand()
创建命令时,它不会自动从DBContext获取超时