Чи є мета, AsQueryable()
щоб ви могли перейти IEnumerable
до методів, які можуть очікувати IQueryable
, чи є корисна причина, щоб представити IEnumerable
як IQueryable
? Наприклад, чи належить це для таких випадків:
IEnumerable<Order> orders = orderRepo.GetAll();
// I don't want to create another method that works on IEnumerable,
// so I convert it here.
CountOrders(orders.AsQueryable());
public static int CountOrders(IQueryable<Order> ordersQuery)
{
return ordersQuery.Count();
}
Або це насправді змушує робити щось інше:
IEnumerable<Order> orders = orderRepo.GetAll();
IQueryable<Order> ordersQuery = orders.AsQueryable();
IEnumerable<Order> filteredOrders = orders.Where(o => o.CustomerId == 3);
IQueryable<Order> filteredOrdersQuery = ordersQuery.Where(o => o.CustomerId == 3);
// Are these executed in a different way?
int result1 = filteredOrders.Count();
int result2 = filteredOrdersQuery.Count();
Чи IQueryable
версії цих методів розширення просто створюють вираз, який в кінцевому підсумку робить те саме, щойно виконується? Моє головне питання - що таке справжній випадок використання AsQueryable
?