学习LINQ TO SQL时,经常会遇到LINQ TO SQL性能问题,这里将介绍LINQ TO SQL性能问题的解决方法
经常和人讨论到LINQ TO SQL性能问题,我们都知道,LINQ TO SQL多少会有一些性能损耗,因为它的查询和操作语句都是动态拼接的。但我也觉得,这不可能是性能的瓶颈所在。
但是,有没有什么办法可以尽量地提高LINQ TO SQL性能吗?
这一篇,我介绍一下对LINQ TO SQL查询进行编译的一个方法
例如我们经常需要按照城市检索,然后输出客户列表,我们可以预先将该语句进行编译,如下面这样定义
public static Func>
CustomersByCity =
CompiledQuery.Compile((Model.NorthwindDataContext db, string city) =>
from c in db.Customers where c.City == city select c);
//对某一类查询进行编译,City可以换,但可以重用该查询
- 1.
- 2.
- 3.
- 4.
- 5.
然后,在我们真正要用的地方就可以像下面这样调用
gv.DataSource = CustomersByCity(new Model.NorthwindDataContext(), "Berlin").Take(10);
gv.DataBind();
- 1.
- 2.
这样就可以尽可能地提高了LINQ TO SQL性能
【编辑推荐】