zoukankan      html  css  js  c++  java
  • linq和ef关于group by取最大值的两种写法

    //LINQ:
    var temp = from p in db.jj_Credentials
                           group p by p.ProfessionID into g
                           select new
                           {
                               g.Key,
                               MaxPrice = g.Max(p => p.CredentialsRankID)
                           };
    
    //EF:
    
    var temp1 = db.jj_Credentials.GroupBy(m => m.ProfessionID).Select(m => m.Max(o => o.CredentialsRankID));
                foreach(var p in temp1)
                {
                    Response.Write(p);
                }
    //补充:取最大值后取得当前完整记录的方法,两种写法:
    
    //写法1
                var list1 = db.jj_Credentials.Where(m => m.UserId == UserContext.UserID && m.IsAudit).OrderByDescending(m => m.CredentialsRankID).ToList().GroupBy(x => x.ProfessionID)
                    .SelectMany(t => t.Select((b, i) => new { b, i }).Where(m => m.i == 0)).Select(m => m.b);
                
                foreach (var i in list1)
                {
                    Response.Write(string.Format("{0} {1} {2} {3}<br>", i.CredentialsID, i.UserId, i.CredentialsRankID, i.ProfessionID));
                }
    
    //写法2
                var list = db.jj_Credentials.Where(m => m.UserId == UserContext.UserID && m.IsAudit).OrderByDescending(x => x.CredentialsRankID).ToList().GroupBy(x => x.ProfessionID)
                .Select(g => new { g, count = g.Count() })
                .SelectMany(t => t.g.Select(b => b).Zip(Enumerable.Range(1, t.count), (j, i) =>
                    new
                    {
                        CredentialsID = j.CredentialsID,
                        UserID = j.UserId,
                        CredentialsRankID = j.CredentialsRankID,
                        ProfessionID = j.ProfessionID,
                        rn = i
                    }).Where(x => x.rn == 1));
    
                //打印
                foreach (var i in list)
                {
                    Response.Write(string.Format("{0} {1} {2} {3}<br>", i.CredentialsID, i.UserID, i.CredentialsRankID, i.ProfessionID));
                }
  • 相关阅读:
    TI DM3730 EBOOT分析(一)
    收费系统三层+抽象工厂+反射实例
    sql语句中的时间查询
    五线谱学习软件
    hdu1061Rightmost Digit(附20循环的规律解法和附快速幂简单原理)
    云计算安全指南
    linux 下orcale基本操作指令
    HDU/HDOJ 2102 A计划 广度优先搜索BFS
    网站优化策略之SEO必知的七大技巧
    SEO之四大要不得
  • 原文地址:https://www.cnblogs.com/jasonlai2016/p/13634415.html
Copyright © 2011-2022 走看看