1

之前没用过Linq,实在没时间学习。我的知识不足以做到这一点,我需要你的帮助。这是我需要转换为 Linq 的代码。(我正在使用 EF6 和上下文)

WITH messages AS (
    SELECT s.siteId,s.originator,s.sentTime,s.mode,s.mainsFrequency,s.gensetFrequency,
            s.dgBattery,s.runHours,s.fuel,s.messageID,s.messageText,
           ROW_NUMBER() OVER(PARTITION BY s.originator 
                                 ORDER BY s.sentTime DESC) AS rk
      FROM smsParseds s)
SELECT m.*
FROM messages m
WHERE m.rk = 1
order by m.sentTime DESC
4

2 回答 2

0

在 Linq 中看到Row_number over (Partition by xxx)? 用于进行分区。

其余的是相当基本的 linq 语法。

我没有对此进行测试或尝试编译它,因此可能需要稍作修改。为了清楚起见,我拆分了类似于问题的查询,但是这些可以很容易地组合成一行。

var messages = smsParseds
   .OrderBy(o => o.sentTime).GroupBy(g => g.originator)
   .Select(s => new {s, rk = s.Count()})
   .SelectMany(sm => sm.s.Select(b => b)
      .Zip(Enumerable.Range(1,sm.rk), (j,i) => new {j.siteId, j.originator, j.sentTime, j.mode, j.mainsFrequency, j.gensetFrequency, j.dgBattery, j.runHours, j.fuel, j.messageID, j.messageText, rk = i}));

var result = messages
   .Where(w => w.rk = 1)
   .OrderByDescending(o => o.sentTime)
于 2014-01-13T19:52:23.610 回答
-1

这不是直接翻译(Entity Framework不能使用Row Number),但是结果应该是一样的

var query = from m in context.Messages
            where (from x in context.Messages
                   where m.Originator == x.Originator
                   where x.SentTime > m.SentTime
                   select x).Any() == false
            orderby m.SentTime desc
            select new
            {
              m.siteId,
              m.originator,
              m.sentTime,
              m.mode,
              m.mainsFrequency,
              m.gensetFrequency,
              m.dgBattery,
              m.runHours,
              m.fuel,
              m.messageID,
              m.messageText,
            };
于 2014-01-13T20:00:03.580 回答