具有Linq,内部Join,Group By,Order By Method语法的实体框架

时间:2016-05-14 06:44:39

标签: entity-framework

我有这个SQL查询:

SELECT 
    COUNT(PID.pid) AS Counted,
    (SELECT TOP 1 Collect_id 
     FROM PID_Control  
     WHERE pid_controlY.org_pid = PID_Control.pid) as Collect_id 
FROM 
    PID 
INNER JOIN  
    PID_Control AS pid_controlY ON PID.pid = pid_controlY.pid 
GROUP BY 
    pid_controlY.Collect_id, pid_controlY.org_pid   

我想在Linq中写同样的内容,但我不确定如何处理这句话:

,(select top 1 Collect_id from PID_Control where pid_controlY.org_pid = 
PID_Control.pid) as Collect_id

我这样做了,??? =错误的行

var list = db.PID_Control
            .Include(t => t.PID1)
            .GroupBy(k => new { k.Collect_id })
            .Select(c => new Grouped
                {
                    Collect_id = ???
                    Counted = c.Select(q => q.PID1.pid1).Count(),
                })
               .ToList();

如何在Linq中制作?

public partial class PID_Control
{
    public int pid_control_id { get; set; }
    public Nullable<int> pid { get; set; }
    public Nullable<int> Collect_id { get; set; }    
    public virtual PID PID1 { get; set; }
}


public partial class PID
{
    public PID()
    {
        this.PID_Control = new HashSet<PID_Control>();
    }
    public int pid1 { get; set; }    
    public virtual ICollection<PID_Control> PID_Control { get; set; }
}

1 个答案:

答案 0 :(得分:0)

我不知道你想要实现的目标,但纯粹关注数据应该这样做:

from pc in db.PID_Controls
group pc by new { pc.Collect_id, pc.pid } into pcgrp
select new Grouped
{
    Collect_Id = pcgrp.SelectMany(pc => pc.PID.PID_Controls)
                      .Select(pc2 => pc2.Collect_id)
                      .FirstOrDefault(),
    Counted = pcgrp.Count()
}
顺便说一下,帮自己一个忙,并使用复数名称来收集(并且遵守其他C#命名惯例也不会造成伤害。)