标签:
原文http://www.cnblogs.com/Mainz/archive/2011/04/08/2009485.html
先看看下面的代码,用了 .AsEnumerable():
var query = (from a in db.Table where a = SomeCondition select a.SomeNumber).AsEnumerable(); int recordCount = query.Count(); int totalSomeNumber = query.Sum(); decimal average = query.Average();
运行起来发现执行了3次而不是1次,查询了3次数据库可不是什么好事情。如果把第一行换成.ToList()那就是只查询一次数据库。
.AsEnumerable()是延迟执行的,实际上什么都没有发生,当真正使用对象的时候(例如调用:First, Single, ToList....的时候)才执行,例如下面的代码:
DataTable orders = ds.Tables["SalesOrderHeader"]; // Query the SalesOrderHeader table for orders placed // after August 8, 2001. IEnumerable<DataRow> query = from order in orders.AsEnumerable() where order.Field<DateTime>("OrderDate") > new DateTime(2001, 8, 1) select order; // Create a table from the query. DataTable boundTable = query.CopyToDataTable<DataRow>(); // Bind the table to a System.Windows.Forms.BindingSource object, // which acts as a proxy for a System.Windows.Forms.DataGridView object. bindingSource.DataSource = boundTable;
但也不应滥用.ToList(),当你需要操作结果的时候,用.ToList(),否则,如果仅仅是用来查询不需要进一步使用结果集,并可以延迟执行,就用.AsEnumerable()/IEnumerable
/IQueryable,例如下例:
using (BlogDbContext context = new BlogDbContext()) { var result = (from e in context.BlogEntries join t in context.PostTexts on e.ID equals t.ID where e.ID == entryId select new { Title = e.Title, Body = t.Text }) .ToList() .Select(e => new BlogEntry() { Title = e.Title, Body = e.Body }) .FirstOrDefault(); }
该例子中的中间结果并没有使用,所以.ToList()可以改为.AsEnumerable()。
.AsEnumerable() 和 .ToList() 的区别:
IEnumerable
/IQueryableIEnumberable接口。但IEnumerable<T> 换成IQueryable<T>后速度提高很多。原因:
namespace System.Linq { public interface IQueryable : IEnumerable { Type ElementType { get; } Expression Expression { get; } IQueryProvider Provider { get; } } public interface IQueryable<out T> : IEnumerable<T>, IQueryable, IEnumerable { } }
LINQ使用细节之.AsEnumerable()和.ToList()的区别
标签:
原文地址:http://www.cnblogs.com/superfeeling/p/4682607.html