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)