Diskuze: ASP. NET MVC vytáhnutí dat z DB
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 6 zpráv z 6.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
var conversions = db.Conversions.Where(t => invoiceConversions.Contains(t.ConversionId));
Jestli jsem to teda dobře pochopil. Příště by nebylo špatné ukázat ten model...
Díky, ten tvůj kod funguje, jen jsem musel upravit ten můj první řádek.
IQueryable<int> conversionIds = db.InvoiceConversions.Where(s => s.ProgramInvoiceId == id).Select(s=>s.ConversionId);
var conversions = db.Conversions.Where(t => conversionIds.Contains(t.Id));
foreach (var conv in conversions)
{
conv.StateId = 1;
db.Entry(conv).State = EntityState.Modified;
}
db.SaveChanges();
Nyní těm konverzím měním stav. Jen nevím, zda to vložení jde taky udělat jen jedním dotazem na DB. Nejsem si jistý zda to db.Entry vytěžuje DB nebo ne. Jde to prosím ještě nějak optimalizovat? díky
No. Zjednodušit to jde takto:
IQueryable<int> conversionIds = db.InvoiceConversions.Where(s => s.ProgramInvoiceId == id).Select(s=>s.ConversionId);
db.Conversions.Where(t => conversionIds.Contains(t.Id)).ToList()..ForEach(s => s.StateId = 1);
db.SaveChanges();
To nastavení stavu na modify by se tam mělo udávat automaticky...
Zjednodušení je to ale spíš syntaktické, kód který si napsal asi už
nezrychlíš. Ten foreach tam prostě být musí...
Kdybys to chtěl ještě víc "zjednodušit" můžeš takto:
db.Conversions.Where(t => (db.InvoiceConversions.Where(s => s.ProgramInvoiceId == id).Select(s=>s.ConversionId)).Contains(t.Id)).ToList().ForEach(s => s.StateId = 1);
db.SaveChanges();
Ale to jsme to spíš "vyšpagetili" než zjednodušili...
Hmm.. jak tak koukam, tak EF je stále pro většinu vývojářů nástroj hromadného ničení :-/
Přitom stačí přečíst 3 stránky textu a každému bude hned jasný rozdíl meti connected/disconnected entitami, jak funguje change tracking atd.
http://www.entityframeworktutorial.net/…amework.aspx
Zobrazeno 6 zpráv z 6.