Search code examples
sql-serverentity-frameworkstored-procedurestimeout

ExecuteReader TimeOut solved by changing the name of the stored procedure


This happened to me today. My MVC.Net application was running fine since few months. Today it caught error when executing this part of code.(this is the simplified version)

var cmd = db.Database.Connection.CreateCommand();
cmd.CommandText = $"mySchema.myStoredProcedureName {param1};
db.Database.CommandTimeout = 0;
db.Database.Connection.Open();  
var reader = cmd.ExecuteReader();

Where db is a DbContext EF6. The timeOut occured on the last line I tried the syntax "using" no success I tried also the following, maybe the connection is not opened

while(db.Database.Connection.State != ConnectionState.Open) {
db.Database.Connection.Open(); }

No! success.

The stored procedure returns result in 2 seconds on SSMS.

Finally I created a similar stored procedure with another name Then it worked.

My question: - Did MSSQL blackList my stored procedure?


Solution

  • I don't think it was blacklisted. Is it possible that your indexes were in need of a rebuild? In other words the renaming really may not have fixed the problem, but some other sort of SQL Server maintenance behind the scenes did?

    My educated guess is the server provider did something to affect you if you did not change any code.