public Handler.PerformanceData.DataTypes.PageDurationDistributionHistogram GetPageDistribution(DateTime forDate, string forPage)
        {
            using (var connection = new SqlConnection(_connectionString)) {
                var cmd = connection.CreateCommand();
                cmd.CommandText = "select Duration from Requests where Timestamp>=@From and Timestamp<@Till";

                if (forPage != null)
                {
                    cmd.CommandText += " and PageId=@PageId";
                    cmd.Parameters.Add(new SqlParameter("PageId", _pageIdProvider.GetPageId(forPage)));
                }

                cmd.Parameters.Add(new SqlParameter("From", forDate));
                cmd.Parameters.Add(new SqlParameter("Till", forDate.AddDays(1)));

                var durations = new List <int>();

                connection.Open();
                using (var rdr = cmd.ExecuteReader()) {
                    while (rdr.Read())
                    {
                        //var pageId = (int)rdr["PageId"];
                        //if(!perPage.ContainsKey(pageId)) {
                        //	perPage[pageId]= new List<int>();
                        //}
                        durations.Add((int)rdr["Duration"]);
                    }
                }

                return(PageDurationDistributionHistogram.FromDistribution(durations.ToArray()));
            }
        }
Пример #2
0
 private static SpecialValues GetSpecialValues(PageDurationDistributionHistogram data)
 {
     return(new SpecialValues {
         _90PercentileBucketIndex = data._90PercentileBucketIndex,
         MedianBucketIndex = data.MedianBucketIndex,
         MeanBucketIndex = data.MeanBucketIndex
     });
 }
 public PageDurationDistributionHistogram GetPageDistribution(DateTime forDate, string forPage)
 {
     FlushNotProcessedPackets();
     lock (_readerLock) {
         List <int> distribution;
         if (forPage == null)
         {
             distribution = GetAllPagesDistribution(forDate);
         }
         else
         {
             distribution = GetPerPageDistributionDictionary(forDate)[forPage];
         }
         return(PageDurationDistributionHistogram.FromDistribution(distribution.ToArray()));
     }
 }