如何优化entity framework的性能

ljyabc1028 2011-07-05 10:11:06
IQueryable<Entity.产品类别> queryTab = null;

queryTab = from type in context.TB_PM_PRODUCT_TYPE.Where(a=>a.DEPTH==3) select type;

平常做查询时,一般都是通过以上方式进行,可不可以优化,提升性能呢;
在网上看到的是--使用EntityKey来查询,不过这是查询单个实体的,而且个人感觉性能也不是十分明显,请大家授教,我的Q是1261370220
...全文
256 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
ljyabc1028 2011-07-05
  • 打赏
  • 举报
回复
今晚回去用存储过程试试
claymore1114 2011-07-05
  • 打赏
  • 举报
回复
可能 第一次 会慢点,后面都会好得多,数据量大的话,相信会比 linq to sql 和ado.net好。
ljyabc1028 2011-07-05
  • 打赏
  • 举报
回复
from type in context.TB_PM_PRODUCT_TYPE where type.TYPE_FID == a select type;

context.TB_PM_PRODUCT_TYPE.MergeOption = MergeOption.NoTracking;
context.TB_PM_PRODUCT_TYPE.Where(a => a.DEPTH == 3);
之前基本老师用这些方式,性能感觉不好,现在就是想优化
q107770540 2011-07-05
  • 打赏
  • 举报
回复
首先你的语句让我感觉写的很别扭
标准表达式和LAMDA表达式混用
不如这样写:

queryTab = from type in context.TB_PM_PRODUCT_TYPE
where type.DEPTH==3
select type;

or:

queryTab = context.TB_PM_PRODUCT_TYPE.Where(a=>a.DEPTH==3);

性能方面,WHERE是延迟查询操作符 已经不影响查询性能了
claymore1114 2011-07-05
  • 打赏
  • 举报
回复
性能 有问题? 感觉 还好了, 不想再用 datatable,dataset了。
老毕 2011-07-05
  • 打赏
  • 举报
回复
设置Context的Log.Out为Console.Out或者其他输出,可以查看LINQ to SQL生成的SQL语句,然后从优化SQL语句反向地来优化LINQ语句。

不过效果真的不明显。个人感觉,使用ADO.NET对象直接访问数据库会快些,用Entity停顿感挺强的。

8,497

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 LINQ
社区管理员
  • LINQ
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧