Вызывает ли применение дополнительных предложений к скомпилированному запросу перекомпиляцию?
Если у меня есть запрос скомпилированных сущностей через CompiledQuery.Compile, а затем я использую другое предложение.Where() или.OrderBy(), принудительно ли эти дополнительные предложения выполняют полную, частичную или не перекомпилировать?
3 ответа
С скомпилированным запросом
public static Func<DataClasses1DataContext, IQueryable<ErrorLog>>
GetErrorLogs = CompiledQuery.Compile
((DataClasses1DataContext context) =>
context.ErrorLogs.Where(el => el.UserName != "foo"));
называется так:
using (DataClasses1DataContext context = new DataClasses1DataContext())
{
context.Log = Console.Out;
var res1 = GetErrorLogs(context).ToList();
var res2 = GetErrorLogs(context).Where(el=>el.ErrorMessage.Contains("foo")).ToList();
}
вывод такой
SELECT [t0].[ErrorLogID], [t0].[ErrorTime], [t0].[UserName], [t0].[ErrorNumber], [t0].[ErrorSeverity], [t0].[ErrorState], [t0].[ErrorProcedure], [t0].[ErrorLine], [t0].[ErrorMessage]
FROM [dbo].[ErrorLog] AS [t0]
WHERE [t0].[UserName] <> @p0
-- @p0: Input NVarChar (Size = 4000; Prec = 0; Scale = 0) [foo]
-- Context: SqlProvider(Sql2008) Model: AttributedMetaModel Build: 4.0.30319.1
SELECT [t0].[ErrorLogID], [t0].[ErrorTime], [t0].[UserName], [t0].[ErrorNumber], [t0].[ErrorSeverity], [t0].[ErrorState], [t0].[ErrorProcedure], [t0].[ErrorLine], [t0].[ErrorMessage]
FROM [dbo].[ErrorLog] AS [t0]
WHERE [t0].[UserName] <> @p0
-- @p0: Input NVarChar (Size = 4000; Prec = 0; Scale = 0) [foo]
-- Context: SqlProvider(Sql2008) Model: AttributedMetaModel Build: 4.0.30319.1
Единственный вывод, что перекомпиляции нет, но .Where(el=>el.ErrorMessage.Contains("foo"))
применяется с LINQ2Objects к объектам, полученным в результате запроса LINQ2SQL.
Все добавленные предложения приводят к другому запросу и, следовательно, к перекомпиляции. Если вы хотите убедиться, что вы не выполняете перекомпиляцию, завершите вызов запроса с помощью .AsEnumerable()
или же .ToList()
, Это материализует запрос, и после этого вы можете делать все, что вам нужно.
Согласно вашему запросу, см. Эту статью msdn.