sql server ExecuteReader需要一个开放且可用的连接。连接的当前状态已关闭

时间:2013-04-08 23:33:26

标签: sql sql-server timeout

我正在使用多线程应用程序从数据库中提取数据,运行几分钟后,我开始得到此异常或sql超时异常。我的代码如下:

    public static List<FlightInfo> FlightInfoAllPricesPerDayForRoute(string From, string To)
    { // Create the object array from the datareader
        List<FlightInfo> arr = new List<FlightInfo>();
        using (var conn = new SqlConnection(sConnectionString))
        {
            using (var command = new SqlCommand("FlightInfoAllPricesPerDayForRoute", conn)
            {
                CommandType = CommandType.StoredProcedure
            })
            {
                conn.Open(); command.CommandTimeout = 150;
                command.Parameters.AddWithValue("AirportFrom", From);
                command.Parameters.AddWithValue("AirportTo", To);
                // command.Parameters.AddWithValue("Date",  dt);


                //execute the stored procedure
                using (IDataReader dr = command.ExecuteReader())
                {


                    FlightInfo obj;

                    while (dr.Read())
                    {
                        obj = new FlightInfo();
                        obj.flightInfoID = (int)dr["FlightInfoID"];
                        obj.airportFrom = (string)dr["AirportFrom"];
                        obj.airportTo = (string)dr["AirportTo"];
                        obj.timeDeparture = DateTime.Parse(dr["TimeDeparture"].ToString());
                        obj.timeArrival = (DateTime)dr["TimeArrival"];
                        obj.price = (short)Int16.Parse(dr["Price"].ToString());
                        obj.dateAdded = (DateTime)dr["DateAdded"];
                        obj.carrier = (string)dr["Carrier"];

                        arr.Add(obj);
                    }

                    dr.Close(); dr.Dispose(); conn.Close(); conn.Dispose(); command.Dispose();


                }
            }
        } return arr;
    }

我在连接字符串中添加了以下内容以改善超时问题,但仍然出现错误:

   Min Pool Size=200;Max Pool Size=32767;Asynchronous Processing=true;   Connect Timeout=150;

存储过程非常简单,所以我认为不存在问题:

select *,  DATEADD(dd, 0, DATEDIFF(dd, 0, TimeDeparture)) as FlightDate
from FlightInfo  
where AirportFrom = @AirportFrom and AirportTo = @AirportTo
AND TimeDeparture > GETDATE() -- Only get future flights
Order by FlightDate ASC, Price asc

我也试过运行它来检查sql连接,但我得到一个'用户无权执行此操作'。错误

  SELECT * FROM sys.dm_exec_connections

任何建议都将不胜感激!

2 个答案:

答案 0 :(得分:1)

您的代码看起来没问题 - 我建议您查看数据库服务器上的问题。如果存储的proc需要很长时间才能运行和/或导致表中的大量锁定,则可能会遇到这些问题(特别是如果经常调用它)。一些查询优化可能是有序的。

fyi - 你不需要在SqlCommand对象周围使用'using'块。此外,您无需在阅读器和连接对象上调用“关闭”和“处理” - “使用”将为您处理。

答案 1 :(得分:0)

使用某些参数运行SP时出现问题,因为插入数据库的代码存在问题,这意味着在某些情况下添加了许多重复的条目。当我尝试使用具有许多重复数据库条目的参数从数据库中提取数据时,SP运行速度非常慢。删除这些重复项改善了这个问题。