How to translate this SQL query to a LINQ query in EF Core?

后端 未结 2 1543
天涯浪人
天涯浪人 2021-01-21 11:28

I have the following table :

Indicators(A INT, B INT, C INT, D INT, TimeInsertedLocal DateTime) . 

And

2条回答
  •  佛祖请我去吃肉
    2021-01-21 11:55

    Of course there are no indicators with a value of TimeInsertedLocal that is larger than the largest value of TimeInsertedLocal of all Indicators.

    However, it might be that you have several indicators with a value equal to the largest value of TimeInsertedLocal.

    If that is the case, you need to make groups of Indicators with the same TimeInsertedLocal, and take the group with the largest value.

    var indicatorsWithLargestTimeInsertedLocal = myDbContext.Indicators
        // make groups of Indicators with same TimeInsertedLocal:
        .GroupBy(indicator => indicator.TimeInsertedLocal)
    
        // put the group with the largest TimeInsertedLocal first:
        .OrderByDescending(group => group.Key)
    
        // The first group of indicators, is the group with the largest value of TimeInsertedLocal
        .FirstOrDefault();
    

    If you are certain the TimeInsertedLocal is unique, you don't have to GroupBy, there will only be one indicator with the largest TimeInsertedLocal

    var indicatorWithLargestTimeInsertedLocal = myDbContext.Indicators
        .OrderByDescending(indicator => indicator.TimeInsertedLocal)
        .FirstOrDefault();
    

提交回复
热议问题