LINQ使用细节之.AsEnumerable和.ToList的区别

 我来答
敬印印心源6
2015-12-23 · TA获得超过173个赞
知道答主
回答量:185
采纳率:0%
帮助的人:61.3万
展开全部
在写LINQ语句的时候,往往会看到.AsEnumerable() 和 .AsQueryable() 。
例如:

[csharp] view plaincopy
string strcon = "Data Source=.\\SQLEXPRESS;Initial Catalog=Db_Example;Persist Security Info=True;User ID=sa;Password=sa";
SqlConnection con = new SqlConnection(strcon);
con.Open();
string strsql = "select * from SC,Course where SC.Cno=Course.Cno";
SqlDataAdapter da = new SqlDataAdapter(strsql,con);
DataSet ds = new DataSet();
da.Fill(ds, "mytable");
DataTable tables=ds.Tables["mytable"]; //创建表
var dslp = from d in tables.AsEnumerable() select d;//执行LINQ语句,这里的.AsEnumerable()是延迟发生,不会立即执行,实际上什么都没有发生
foreach(var res in dslp)
灵德
2024-11-19 广告
由化工方面的博士、教授和企业的高级技术人员与管理人员创建的高科技化工企业。主要从事下列产品的开发、生产和相关的技术服务:▼高纯电子化学品(主要为高纯季铵碱 )▼季铵碱系列▼季铵盐系列▼季膦化合物系列▼相转移催化剂(PTC)▼均苯四甲酸 (P... 点击进入详情页
本回答由灵德提供
愈生爱唠叨的人
2015-12-23 · TA获得超过913个赞
知道大有可为答主
回答量:886
采纳率:0%
帮助的人:1752万
展开全部
这是一个延迟执行(Deferred excution)的问题。
当调用where时,实际得到的不是集合,而是运算表达式,直到ToList时,才成为对应的集合。在循环中,运算式中的变量值发生了变化(category),等同于如下代码,所以 levellist1 levellist2在执行时
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式