0

我想在 C# 中以特定间隔从数据库中获取值,并且需要一个 LINQ 查询。这就是我的数据库的样子

Id      SensorId  Value       CreatedOn   

1         8        33.5       15-11-2012  5:48 PM     
2         5        49.2       15-11-2012  5:48 PM 
3         8        33.2       15-11-2012  5:49 PM
4         5        48.5       15-11-2012  5:49 PM
5         8        31.8       15-11-2012  5:50 PM  
6         5        42.5       15-11-2012  5:50 PM  
7         8        36.5       15-11-2012  5:51 PM  
8         5        46.5       15-11-2012  5:51 PM  
9         8        39.2       15-11-2012  5:52 PM  
10        5        44.4       15-11-2012  5:52 PM  
11        8        36.5       15-11-2012  5:53 PM  
12        5        46.5       15-11-2012  5:53 PM  
13        8        39.2       15-11-2012  5:54 PM  
14        5        44.4       15-11-2012  5:54 PM  
..        .        ....       ...................

间隔以分钟为单位。所以,如果间隔是 10 分钟,那么我们需要 5:48、5:58、6:08 等处的值...

这是我尝试过的

while (startDateTime <= endDateTime)
            {
               var fetchIndex =
                    fullValues.Where(
                        item =>
                        item.CreatedOn >= startDateTime &&
                        item.CreatedOn < startDateTime.AddMinutes(1)).Select(
                            item => item.FetchIndex).FirstOrDefault();
                if (fetchIndex != 0)
                {
                    var temp = fullValues.Where(item => item.FetchIndex == fetchIndex).ToList();
                    result = result.Union(temp);
                }

                startDateTime = startDateTime.AddMinutes(interval);
            }

由于 while 循环遍历表,因此需要花费大量时间来获取这些值。

有没有办法在单个查询中获取数据?

4

2 回答 2

2

以下方法创建一个列表,其中包含和requiredTimes之间的所有相关日期时间(开始和结束日期时间之间的 10 分钟间隔中的日期时间)。创建此类列表后,将在其上进行内部连接。结果是一个 IEnumerable,其中包含满足间隔条件的日期时间。它应该工作得很快,因为创建这样的列表很快,而且该方法是一个内部连接,它也应该工作得很快,试试吧:startDateTimeendDateTimefullValuesfullValuesJoin

        DateTime startDateTime = DateTime.Parse("15-11-2012 5:48 PM");
        DateTime endDateTime = DateTime.Parse("16-11-2012 5:58 PM");

        List<DateTime> requiredTimes = new List<DateTime>();

        DateTime dt = startDateTime;
        requiredTimes.Add(dt);
        while (dt <= endDateTime)
        {
            dt = dt.AddMinutes(10);
            requiredTimes.Add(dt);
        }

        var result = fullValues.Join(
            requiredTimes,
            fv => fv.CreatedOn,
            rt => rt,
            (fv, rt) => fv);
于 2012-11-29T07:36:19.483 回答
2
from x in table
where   x.CreatedOn >= startDateTime &&
        x.CreatedOn <= endDateTime &&
        (x.CreatedOn.Minute % 10) == 0
select x

这会给你 1:00,1:10,1:20

10 代表您的间隔,0 是您的偏移量。

于 2012-11-29T07:06:24.247 回答