加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

.net – LINQ to SQL – 按小时分组

发布时间:2020-12-12 06:25:01 所属栏目:MsSql教程 来源:网络整理
导读:考虑到列类型是DateTime,如何将LINQ到SQL查询的结果分组? 解决方法 这是解决技术小时(上下文)的一个解决方案. var query = myDC.Orders .GroupBy(x = x.OrderDate.Hour) .Select(g = new { Hour = g.Key,Amount = g.Sum(x = x.OrderAmount) }); 哪个产生这个
考虑到列类型是DateTime,如何将LINQ到SQL查询的结果分组?

解决方法

这是解决技术小时(上下文)的一个解决方案.
var query = myDC.Orders
    .GroupBy(x => x.OrderDate.Hour)
    .Select(g => new {
        Hour = g.Key,Amount = g.Sum(x => x.OrderAmount)
    });

哪个产生这个:

SELECT SUM([t1].[OrderAmount]) AS [Amount],[t1].[value] AS [Hour]
FROM (
    SELECT DATEPART(Hour,[t0].[OrderDate]) AS [value],[t0].[OrderAmount]
    FROM [dbo].[Orders] AS [t0]
    ) AS [t1]
GROUP BY [t1].[value]

这是一个营业时间的解决方案(上下文).

DateTime zeroDate = new DateTime(2008,1,1);

var query = myDC.Orders
    .GroupBy(x => System.Data.Linq.SqlClient.SqlMethods.DateDiffHour(zeroDate,x.OrderDate)
    )
    .Select(g => new { Hours = g.Key,Amount = g.Sum(x => x.OrderAmount) })
    .Select(x => new { Hour = zeroDate.AddHours(x.Hours),Amount = x.Amount});

哪个产生这个:

SELECT DATEADD(ms,(CONVERT(BigInt,(CONVERT(Float,[t2].[value2])) * 3600000)) % 86400000,DATEADD(day,[t2].[value2])) * 3600000)) / 86400000,@p1)) AS [Hour],[t2].[value] AS [Amount]
FROM (
    SELECT SUM([t1].[OrderAmount]) AS [value],[t1].[value] AS [value2]
    FROM (
        SELECT DATEDIFF(Hour,@p0,[t0].[OrderAmount]
        FROM [dbo].[Orders] AS [t0]
        ) AS [t1]
    GROUP BY [t1].[value]
    ) AS [t2]

嗯 – 那个bigint / float /毫秒的东西是丑陋和难以验证.我更喜欢在客户端添加:

var results = myDC.Orders
    .GroupBy(x => System.Data.Linq.SqlClient.SqlMethods.DateDiffHour(zeroDate,Amount = g.Sum(x => x.OrderAmount) })
    .ToList()
    .Select(x => new { Hour = zeroDate.AddHours(x.Hours),Amount = x.Amount});

哪个产生这个:

SELECT SUM([t1].[OrderAmount]) AS [Amount],[t1].[value] AS [Hours]
FROM (
    SELECT DATEDIFF(Hour,[t0].[OrderAmount]
    FROM [dbo].[Orders] AS [t0]
    ) AS [t1]
GROUP BY [t1].[value]

这是做上下文时间的第三种方式.这个非常c#友好,但数据库中有字符串逻辑(yuck).

var query = myDC.Orders
    .GroupBy(x => new DateTime(x.OrderDate.Year,x.OrderDate.Month,x.OrderDate.Day,x.OrderDate.Hour,0))
    .Select(g => new { Hour = g.Key,Amount = g.Sum(x => x.OrderAmount) });

哪个生成

SELECT SUM([t1].[OrderAmount]) AS [Amount],[t1].[value] AS [Hour]
FROM (
    SELECT CONVERT(DATETIME,(CONVERT(NCHAR(4),DATEPART(Year,[t0].[OrderDate])) + ('-' + (CONVERT(NCHAR(2),DATEPART(Month,[t0].[OrderDate])) + ('-' + CONVERT(NCHAR(2),DATEPART(Day,[t0].[OrderDate])))))) + (' ' + (CONVERT(NCHAR(2),DATEPART(Hour,[t0].[OrderDate])) + (':' + (CONVERT(NCHAR(2),@p0) + (':' + CONVERT(NCHAR(2),@p1)))))),120) AS [value],[t0].[OrderAmount]
    FROM [dbo].[Orders] AS [t0]
    ) AS [t1]
GROUP BY [t1].[value]

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读