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

Svi*_*ish 5 c# performance linq-to-sql

鉴于以下代码:

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

  foreach(Something in data.Somethings)
     someList.Add(something.SomeProperty);
}
Run Code Online (Sandbox Code Playgroud)

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

Mar*_*ell 10

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

  • 也许为数据上下文写一个"流畅的"扩展方法(下)
  • 通过添加OnCreated执行它的部分方法使其成为默认值

流畅的扩展示例:

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

}
Run Code Online (Sandbox Code Playgroud)

然后你可以使用:

using(var data = new SomeDataContext(ConnectionString).NoTracking())
{...}
Run Code Online (Sandbox Code Playgroud)

部分方法示例:

namespace MyData {
    partial class MyDataContext {
        partial void OnCreated() {
            this.ObjectTrackingEnabled = false;
        }
    }
}
Run Code Online (Sandbox Code Playgroud)