如何修复System.Data.SqlClient.SqlException:超时已过期

时间:2013-02-15 16:48:16

标签: asp.net sql sql-server-2008

嗨当我尝试通过URL访问我的应用程序时,我收到包含以下错误的错误屏幕。以前我通过在backend..bt中使用dbcc命令来修复它现在这不起作用..

超时已过期。操作完成之前经过的超时时间或服务器没有响应。 描述:执行当前Web请求期间发生未处理的异常。请查看堆栈跟踪以获取有关错误及其源自代码的位置的更多信息。

异常详细信息:System.Data.SqlClient.SqlException:超时已过期。操作完成之前经过的超时时间或服务器没有响应。

来源错误:

在执行当前Web请求期间生成了未处理的异常。可以使用下面的异常堆栈跟踪来识别有关异常的起源和位置的信息。

这是我从.NET应用程序调用的存储过程的源代码。

      USE [TCO]
GO
      ALTER PROC [dbo].[SP_TCOV3] (@year INT) AS
DECLARE @rpt_year INT;
IF @year > 2011 
BEGIN
SET @rpt_year = 2011;
END
ELSE
BEGIN   
SET @rpt_year = @year;
END
DECLARE @From_Date DATETIME='01-01-2012'  -- mm/dd/yyyy
DECLARE @End_Date DATETIME=(SELECT TOP 1 DATEADD(dd, -DAY(DATEADD(m,1,dbo.ManpowerCost.payment_date)), DATEADD(m,1,dbo.ManpowerCost.payment_date)) as value
FROM dbo.ManpowerCost order by payment_date desc)  

(
SELECT
        allApps.[Application Name],          
        '$'+(CAST((CAST(allApps.[BAM Staff Support] AS DECIMAL(10,2))) as varchar(50)))AS [BAM Staff Support],
        '$'+(CAST((CAST(allApps.[BAM Non-Shell Support] AS DECIMAL(10,2))) as varchar(50)))AS [BAM Non-Shell Support] ,
        '$'+(CAST((CAST(allApps.[BSM DBA Support] AS DECIMAL(10,2))) as varchar(50)))AS [BSM DBA Support] ,
        '$'+(CAST((CAST(allApps.[Middleware Support] AS DECIMAL(10,2))) as varchar(50)))  AS [BSM Middleware Support],
        '$'+(CAST((CAST(allApps.[IRM Logical Access] AS DECIMAL(10,2))) as varchar(50)))AS [IRM Logical Access] ,
        '$'+(CAST((CAST(allApps.[Application Licensing and Maintenance] AS DECIMAL(10,2))) as varchar(50))) AS [Application License and Maintenance],
        '$'+(CAST((CAST(allApps.[Middleware Licensing and Maintenance] AS DECIMAL(10,2))) as varchar(50)))as [Middleware License and Maintenance],  
        '$'+(CAST((CAST(allApps.[Database Licensing and T-System DBA Maintenance] AS DECIMAL(10,2))) as varchar(50))) AS [TS DBA Maintenance],
        '$'+(CAST((CAST(allApps.[Hosting and Storage] AS DECIMAL(10,2))) as varchar(50)))AS [Hosting and Storage]  ,
        '$'+(CAST((CAST(allApps.[Telecom Connection Charge] AS DECIMAL(10,2))) as varchar(50))) AS [Telecom Connection Charges],
        '$'+(CAST((CAST(allApps.[Total Application TCO] AS DECIMAL(10,2))) as varchar(50)))AS [Total Application TCO] 
FROM
        --dbo.FN_TCOV3(@rpt_year)AS allApps 
        dbo.FN_TCOV3_Report(@From_Date,@End_Date)AS allApps 

)ORDER BY allApps.[Application Name]

如果我不使用上面使用的开始日期和结束日期参数,那么相同的proc工作正常 并调用 dbo.FN_TCOV3(@rpt_year)AS allApps 而不是dbo.FN_TCOV3_Report(@ From_Date,@ End_Date)AS allApps,唯一的差异。 b / w这两个函数是一个只用一年作为参数而另一个作为2个参数即开始和结束日期。

我需要使用这两个参数,请帮助。

2 个答案:

答案 0 :(得分:6)

如果您的查询确实需要长时间运行,则可以通过设置CommandTimeout对象的SqlCommand属性来延长TimeOut周期({{1}超时5分钟;也相应设置相应的页面Server TimeOut

也就是说,如果你不知道为什么你的查询运行的时间很长,你必须调查并修复它。

搜索:

  • 缺少索引
  • 低效算法

答案 1 :(得分:0)

在Sql Server Management Studio中,突出显示查询和 单击“显示估计执行计划”。 Index Seek很好。如果有索引扫描, 在表上的列上创建索引。 这解决了我的问题。