Diskuze: Vlastní logování pro entity framework
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 9 zpráv z 9.
//= 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.
Ahoj, nějak jsem nepochopil, jestli ti jde o to, že EF volá na databázi
šíleně komplexní dotazy nebo máš problém pouze s logováním?
Pokud je to první možnost, pak tě asi zklamu, ale EF se je snaží
optimalizovat, co se dá. Řešení, co mě napadají, je neskládat brutálně
komplexní LINQ dotazy (typicky x-krát zopakovaný Include a nebo použít čisté sql,
často vytvoříš jednodušší verzi dotazu co vyplivne EF, protože zdaleka
není dokonalý :/
V druhém případě nepomůžu, neboť NLog nepoužívám
Díky za odpověď. Myslel jsem druhou možnost. Ono asi nezáleží že používám nlog. To logování ef dotazů je stejné. Ale chtěl bych si je nějak podle sebe upravit
OK, nevím jak to logování děláš teď (a možná ti řeknu jenom co
víš), ale dá se vydat směrem DbContext.Database.Log, kam si vhodíš
vlastní akci se stringovským parametrem (Action<string>, kde vstupní
string je daný dotaz), a v ní si můžeš převzít otěže, zpracovat si
dotaz jak chceš a zalogovat.
např.výpis do konzole
public SomeDataContext()
{
this.Database.Log = Console.WriteLine;
}
Každopádně úprava komplexních dotazů bude celkem pakárna
Tak bohužel tohle jde jenom v ef6... Ale já dělám v .net coru
Doporučuju "Interception". Neměl by být problém k tomu dohledat informace.
Díky moc to je ono EF Core
to v základu nemá, ale ja na to externí knihovna. Shodou okolností jsem si
aktualizoval EF na verzi 3.0 a zde musím říct, žde logování je o dost
lepší. I Tak díky moc a níže je odkaz.
Zobrazeno 9 zpráv z 9.