Я написал этот код LINQ:
from workTask in VwWorkTask.Where(e => e.TaskStateStr != "A"
&& e.TaskStateStr != "B")
join workContext in TblWorkTOBProlongationWorkContexts
on workTask.WorkContextId equals workContext.Id
join client in VwClient
on workContext.Client equals client.ClientId into t1
from client in t1.DefaultIfEmpty()
....// other joins
select workTask
, который генерирует этот запрос T-SQL:
SELECT [t0].*
FROM [vwWorkTask] AS [t0]
INNER JOIN [tblWorkTOBProlongationWorkContext] AS [t1]
ON [t0].[WorkContextId] = ([t1].[Id])
LEFT OUTER JOIN [vwClient] AS [t2] ON [t1].[Client] = [t2].[ClientId]
... -- other joins
WHERE ([t0].[TaskStateStr] <> @p0) AND ([t0].[TaskStateStr] <> @p1)
Но мне нужно что-то вроде этого:
SELECT [t0].*
FROM [select * vwWorkTask WHERE ([t0].[TaskStateStr] <> @p0)
AND ([t0].[TaskStateStr] <> @p1)] AS [t0]
INNER JOIN [tblWorkTOBProlongationWorkContext] AS [t1]
ON [t0].[WorkContextId] = ([t1].[Id])
LEFT OUTER JOIN [vwClient] AS [t2] ON [t1].[Client] = [t2].[ClientId]
... -- other joins
Другими словами, мне нужен вложенный запрос с проверкой "где" до всех соединений, а не после.Любые идеи, как я могу переписать запрос LINQ для достижения этой цели?
Спасибо.