Varlık çerçevesi içinde geliştirmek bulk ınsert performans
Varlık çerçevesi tarafından bir tablo 20000 kayıtları eklemek istiyorum ve yaklaşık 2 dakika sürer. Herhangi bir şekilde SP performansını artırmak için kullanma. Bu benim kod:
foreach (Employees item in sequence)
{
t = new Employees ();
t.Text = item.Text;
dataContext.Employees.AddObject(t);
}
dataContext.SaveChanges();
CEVAP
Çeşitli geliştirmeler DbContext kullanıyorsanız () için fırsat var:
Set:
yourContext.Configuration.AutoDetectChangesEnabled = false;
yourContext.Configuration.ValidateOnSaveEnabled = false;
100 ekler paketler halinde SaveChanges()... ... veya 1000 öğeleri paketleri ile deneyin ve performans değişiklikleri görebilirsiniz.
Tüm bu ekler, içeriği aynı ve daha büyük oluyor bu bağlamda her 1000 ekler nesneyi yeniden oluşturun. var yourContext = new YourContext(); büyük bir kazanç olduğunu düşünüyorum.
Benim veri alma işlemi bu iyileştirmeleri yapmak, 6 saniye 7 dakika sürdü.
Gerçek rakamlar... 100 o senin durumda 1000 olamazdı... bu da bir dene çimdik.

Set veritabanı Varlık Çerçevesi içinde...
Eğer bir nesne zaten Varlık Çerçevesi ...
Nasıl varlık çerçevesi içinde null değ...
Nasıl Varlık Çerçevesi içinde Çetelele...
Varlık Çerçevesi: &; Store update, ıns...