Zdravím dělám v .net core a používám EF a NLog. Vše funguje jak má.
Jde mi ale o to, že logování EF dotazů jsou opravdu příšerné... Když si
to pak chce člověk provolat v managment studiu, tak trpí... Takže se chci
zeptat jestli neexistuje něco co ty příkazy "zlepší" a nebo něco, kde si
sám napíšu logiku toho logování.
Zkusil jsem: Zkoušel jsem googlit, ale nic moc jsem nanešel. Možná ten
dotaz interpretuju divně. mám pocit že jsem jednou viděl článek v .net
frameworku, kde se zdálo že to není problém.
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
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.
Děláme co je v našich silách, aby byly zdejší diskuze co nejkvalitnější. Proto do nich také mohou přispívat pouze registrovaní členové. Pro zapojení do diskuze se přihlas. Pokud ještě nemáš účet, zaregistruj se, je to zdarma.