c# - 将 SQL Rank() 转换为 LINQ 或替代方法

标签 c# sql linq linq-to-sql

我有下面的 SQL 语句,可以按预期/预期工作。但是我想将它翻译成 LINQ 语句(Lambda??),以便它适合我的 DAL 的其余部分。但是我看不出如何在 LINQ 中模拟 Rank()。

我将其张贴在这里的原因(可能有误)是想看看是否有人可以替代 Rank() 语句,以便我可以将其切换。或者,如果有一种方法可以在 LINQ 中表示 Rank(),我们也将不胜感激。

USE CMO

SELECT      vp.[PersonID] AS [PersonId]
            ,ce.[EnrollmentID]
            ,vp.[FirstName]
            ,vp.[LastName]
            ,ce.[EnrollmentDate]
            ,ce.[DisenrollmentDate]
            ,wh.WorkerCategory

FROM  [dbo].[vwPersonInfo] AS vp
            INNER JOIN 
            (
                  [dbo].[tblCMOEnrollment] AS ce
                  LEFT OUTER JOIN
                        (
                              SELECT   *
                                          ,RANK()OVER(PARTITION BY EnrollmentID ORDER BY CASE WHEN EndDate IS NULL THEN 1 ELSE 2 END, EndDate DESC, StartDate DESC) AS whrank 
                              FROM  [dbo].[tblWorkerHistory]
                              WHERE WorkerCategory = 2
                        ) AS wh 
                              ON ce.[EnrollmentID] = wh.[EnrollmentID] AND wh.whrank = 1
            ) 
                  ON vp.[PersonID] = ce.[ClientID]

WHERE (vp.LastName NOT IN ('Client','Orientation','Real','Training','Matrix','Second','Not'))
AND (
            (wh.[EndDate] <= GETDATE())
            OR wh.WorkerCategory IS NULL
      ) 
AND (
            (ce.[DisenrollmentDate] IS NULL) 
            OR (ce.[DisenrollmentDate] >= GetDate())
      )

最佳答案

这是一个示例,展示了我将如何在 Linq 中模拟 Rank():

var items = new[]
{
    new { Name = "1", Value = 2 },
    new { Name = "2", Value = 2 },
    new { Name = "3", Value = 1 },
    new { Name = "4", Value = 1 },
    new { Name = "5", Value = 3 },
    new { Name = "6", Value = 3 },
    new { Name = "7", Value = 4 },
};
  
var q = from s in items
    orderby s.Value descending
    select new 
    { 
        Name = s.Name, 
        Value = s.Value,
        Rank = (from o in items
                where o.Value > s.Value
                select o).Count() + 1 
    };

foreach(var item in q)
{
    Console.WriteLine($"Name: {item.Name} Value: {item.Value} Rank: {item.Rank}");
}

输出

Name: 7 Value: 4 Rank: 1
Name: 5 Value: 3 Rank: 2
Name: 6 Value: 3 Rank: 2
Name: 1 Value: 2 Rank: 4
Name: 2 Value: 2 Rank: 4
Name: 3 Value: 1 Rank: 6
Name: 4 Value: 1 Rank: 6

关于c# - 将 SQL Rank() 转换为 LINQ 或替代方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9873962/

相关文章:

c# - CancellationToken 泄漏内存

c# - EntityFramework ToListAsync() 不起作用

MySQL按时间段对结果进行分组

c# - 在这种情况下,LINQ是最好的解决方案吗? LINQ到数据集

c# - List<Object> 到层次结构

c# - 使用 LINQ 从树数据结构中获取级别的最佳方法是什么?

c# - 在 C# 中找到直线与 X 轴的最小角度

mysql - 选择具有相等列 (c1) 值的行并添加另一个列 (c2) 值。对列 c1 的所有不同列值执行相同的操作

c# - 如何将外部列表集成到原始 sql 查询连接作为 linq 原始 sql 查询中的表

c# - 是否可以使 Action 方法中的数据在 Action 过滤器中可用?