我試圖做一個「左連接」。左連接實體框架未運行
但是,只有當我有「在這兩個表」中的信息時,該命令纔會返回一些內容。
婁我的功能
public IList<ClientWorkFlowReadModel> GetWorkFlow(int idClient)
{
try
{
using (GvisaContext db = new GvisaContext())
{
//Disable de proxy tracking for prevent error in json convertion
db.Configuration.ProxyCreationEnabled = false;
var clientServiceWorkFlows = db.ServicesWorkFlow
.Join(db.ClientsServicesWorkFlow,
swf => swf.IdServiceWorkFlow,
cswf => cswf.IdServiceWorkFlow,
(swf, cswf) =>
new { swf, cswf })
.Select(x => new ClientWorkFlowReadModel {
Title = x.swf.Title,
IdClient = x.cswf.IdClient,
IdService = x.swf.IdService,
IdClientServiceWorkFlow = x.cswf.IdClientServiceWorkFlow,
Description = x.swf.Description,
Active = x.swf.Active,
DateUpdate = x.cswf.DateUpdate
}
).Where(y => y.IdClient == idClient).ToList();
return clientServiceWorkFlows;
}
}
catch (Exception ex)
{
throw ex;
}
我需要這樣做:
SELECT * FROM dbo.Clients z
INNER JOIN dbo.ClientsServices y on y.idClient=z.idClient
INNER JOIN dbo.ServicesWorkFlow a on a.IdService=y.IdService
LEFT JOIN ClientsServicesWorkFlow b on b.IdClientServiceWorkFlow=a.IdServiceWorkFlow
WHERE z.IdClient=3
感謝!
當與EF工作,[不使用Linq的加入。導航!](https://coding.abel.nu/2012/06/dont-use-linqs-join-navigate/) –