C#:ObjectTrackingEnabled = false值得为小型操作吗?

时间:2009-02-10 13:05:54

标签: c# performance linq-to-sql

给出以下代码:

using(var data = new SomeDataContext(ConnectionString))
{
  data.ObjectTrackingEnabled = false;

  foreach(Something in data.Somethings)
     someList.Add(something.SomeProperty);
}

将对象跟​​踪设置为false是否值得?我知道这只是一行代码,但是我不得不一直写它。但是我听说你可以通过在不需要的时候转动它来获得一些性能提升。由于我只需要快速读出一些数据,我不需要跟踪。但是这么一小段代码值得吗?你有什么意见?我应该用吗?我不应该吗?为什么呢?

1 个答案:

答案 0 :(得分:10)

如果上下文将立即处理,可能不值得 - 但这里有一些想法:

  • 也许为数据上下文写一个“流畅的”扩展方法(下面)
  • 将其设为默认值,方法是添加部分OnCreated方法

Fluent扩展示例:

public static class DataContextExt {
    public static T NoTracking<T>(this T ctx)
        where T : DataContext
    {
        ctx.ObjectTrackingEnabled = false;
        return ctx;
    }   

}

然后你可以使用:

using(var data = new SomeDataContext(ConnectionString).NoTracking())
{...}

部分方法示例:

namespace MyData {
    partial class MyDataContext {
        partial void OnCreated() {
            this.ObjectTrackingEnabled = false;
        }
    }
}