Code Keeps Timing Out

后端 未结 4 1631
南笙
南笙 2021-01-22 18:18

So, we\'ve got this set of code that, for some reason, keeps timing out. It\'s not the stored procedure that it\'s running, because that runs fine. Also, if we remove the para

相关标签:
4条回答
  • 2021-01-22 18:41

    have you tried

    myCommand.Parameters.AddWithValue("@studynumber", studynumber);
    

    instead of:

    myCommand.Parameters.AddWithValue("@study", studynumber); 
    
    0 讨论(0)
  • 2021-01-22 18:50

    One thing could be the ARITHABORT setting, set it to ON...NET defaults to OFF

    run the proc in SSMS with ARITHABORT set to OFF and see if it runs slower now like from .NET

    example

    MyConnection.Execute "SET ARITHABORT ON"
    

    Another thing is that your WHERE clause is not optimal, take a look at Do you use Column=@Param OR @Param IS NULL in your WHERE clause? Don't, it doesn't perform

    does the proc run slow with parameters in SSMS? Can you show the execution plan?

    0 讨论(0)
  • 2021-01-22 18:53

    EDIT If passing parameters is the problem, then it comes down to how much time the stored procedure takes to execute. Default timeout for SQL server is usually 120 secs. You can add "Connect Timeout" to increase timeout in your DB connection string and check out.

    ** Old Answer -- Ignore ** Without stack trace, and taking your word that the stored procedure is fine, I am guessing that it is timing out due to the connection failure. The code is unable to connect to your DB server and hence timing out.

    0 讨论(0)
  • 2021-01-22 18:56

    setting arithabort off made the sp take 45 seconds as opposed to 1. setting it back on changed it back to 1. I updated the stored procedure to set it on, no change in the app. Changed it to off, no change. I then removed the update and then the app worked fine.

    I believe what happened is that updating the stored procedure caused it to recompile, fixing the issue. I'm not 100% sure on this though.

    0 讨论(0)
提交回复
热议问题