|
|
PostitatudEile kell 20:48
|
|
|

Nõuded: Mõned andmed võimaldavad roppu lugemist, nagu artikli sisu, lehevaatamised, kommentaarid jne, mis ei ole nii põhjalikud kui finantsandmed. Päringute jõudluse parandamiseks võib kasutada ReadUncomcommiteeritud tehinguid, kuid SqlTransactionil ja TransactionScope'il on lekkeisolatsiooni taseme vead, mida pole veel parandatud, seega kaaluge WITH (NOLOCK) lahenduse kasutamist.
Läbivaatamine:
SqlTransaction ja TransactionScope lekkeisolatsiooni tasemed (see viga on olnud 8 aastat ja pole siiani parandatud!) Ma arvan, et paljud inimesed võivad olla mõjutatud, kuid nad ei pruugi seda mõista):Hüperlingi sisselogimine on nähtav.
See artikkel peab viitama SqlScriptDOM-ile SQL-lausete parsimiseks ja lisama WITH(NOLOCK). Vaata avatud lähtekoodiga projekti:Hüperlingi sisselogimine on nähtav.
Nuget tsiteerib järgmiselt:
Loo uus AllowDirtyReadAttribute.cs funktsioon, kood järgmiselt:
Loo uus WithNoLockInterceptor, et üle kirjutada teatud meetodid DbCommandInterceptoris. Kood on järgmine:
Sisesta EF Core'i järgmise konfiguratsiooniga:
Kasuta, et lisada see kontrolleri meetodi kohale[LubaMustaLugeda]Võib.
Toore SQL-lause:
VALI [o]. [id], [o]. [KliendiNimi], [o0]. [id], [o0]. [OrderId], [o0]. [Toode] ALATES [Käsk] KUI [o] VASAK VÄLISÜHENDUS [OrderLines] AS [o0] ON [o]. [id] = [o0]. [OrderId] KUS [o]. [id] = 1 KÄSK [o]. [id]; Avaldus, mis genereeritakse pärast NOLOCKi lisamist:
VALI [o]. [id], [o]. [KliendiNimi], [o0]. [id], [o0]. [OrderId], [o0]. [Toode] ALATES [Käsk] KUI [o] KOOS (NOLOCK) VASAK VÄLISÜHENDUS [OrderLines] AS [o0] KOOS (NOLOCKIGA) ON [o]. [id] = [o0]. [OrderId] KUS [o]. [id] = 1 KÄSK [o]. [id]; |
Eelmine:(MSSQL) SQL Server täisteksti otsing, täisteksti indeks
|