تحتاج إلى مساعدة في تحويل الاستعلام مع توصيلات ومجموعة من/العد إلى LINQ إلى SQL
-
06-07-2019 - |
سؤال
أحتاج إلى مساعدة في تحويل هذا الاستعلام إلى LINQ إلى SQL:
select
rd.RouteDispatchID,
r.RouteNumber,
s.ShortDescription Status,
rd.DispatchDate,
rd.CreationDate CreatedDate,
e.FirstName,
e.LastName,
count(md.MachineDispatchID) NumMachines
from
dbo.RouteDispatch rd
inner join dbo.Route r on rd.RouteID = r.RouteID
inner join dbo.Reference s on rd.StatusCodeReferenceID = s.ReferenceID
inner join dbo.Employee e on rd.CreatedByEmployeeID = e.EmployeeID
left join dbo.MachineDispatch md on rd.RouteDispatchID = md.RouteDispatchID and md.IsSelected = 1
إليك ما لدي حتى الآن ، لكن لا يمكنني معرفة كيفية الحصول على المجموعة عن طريق/العد للعمل ولا يمكن لأي أداة linqer ...
var query = from rd in db.RouteDispatches
join r in db.Routes on rd.RouteID equals r.RouteID
join s in db.References on new { StatusCodeReferenceID = rd.StatusCodeReferenceID } equals new { StatusCodeReferenceID = s.ReferenceID }
join e in db.Employees on new { CreatedByEmployeeID = rd.CreatedByEmployeeID } equals new { CreatedByEmployeeID = e.EmployeeID }
join md in db.MachineDispatches
on new { RouteDispatchID = rd.RouteDispatchID, IsSelected = true }
equals new { RouteDispatchID = md.RouteDispatchID, IsSelected = md.IsSelected.Value } into md_join
from md in md_join.DefaultIfEmpty()
select new RouteView {
RouteDispatchID = rd.RouteDispatchID,
RouteNumber = r.RouteNumber,
Status = s.ShortDescription,
DispatchDate = rd.DispatchDate.Value,
CreatedDate = rd.CreationDate.Value,
FirstName = e.FirstName,
LastName= e.LastName,
NumMachines = 0//.Count()
};
بفضل من يمكنه معرفة ذلك ، ما زلت مبتدئًا مع LINQ إلى SQL ، لذا فأنا أخرج من 2-3 أسئلة جديدة يوميًا !! قون
المحلول
حصلت عليها تعمل ...
var query = from rd in db.RouteDispatches
join r in db.Routes on rd.RouteID equals r.RouteID
join s in db.References on new { StatusCodeReferenceID = rd.StatusCodeReferenceID } equals new { StatusCodeReferenceID = s.ReferenceID }
join e in db.Employees on new { CreatedByEmployeeID = rd.CreatedByEmployeeID } equals new { CreatedByEmployeeID = e.EmployeeID }
join md in db.MachineDispatches
on new { RouteDispatchID = rd.RouteDispatchID, IsSelected = true }
equals new { RouteDispatchID = md.RouteDispatchID, IsSelected = md.IsSelected.Value } into md_join
from md in md_join.DefaultIfEmpty()
group new { rd, r, s, e, md } by new
{
rd.RouteDispatchID,
r.RouteNumber,
s.ShortDescription,
rd.DispatchDate,
rd.CreationDate,
e.FirstName,
e.LastName
} into g
select new RouteView
{
RouteDispatchID = (System.Int32)g.Key.RouteDispatchID,
RouteNumber = g.Key.RouteNumber,
Status = g.Key.ShortDescription,
DispatchDate = (System.DateTime)g.Key.DispatchDate,
CreatedDate = (System.DateTime)g.Key.CreationDate,
FirstName = g.Key.FirstName,
LastName = g.Key.LastName,
NumMachines = g.Count(),
TotalRecordCount = 0
};
لا تنتمي إلى StackOverflow