Waarom zijn opgeslagen procedures sneller?
Waarom zijn opgeslagen procedures sneller?
Anonim

Uw verklaring dat Opgeslagen procedures zijn sneller dan SQL-query's is slechts gedeeltelijk waar. Dus als je de belt opgeslagen procedure nogmaals, de SQL-engine doorzoekt eerst de lijst met queryplannen en als hij een overeenkomst vindt, gebruikt hij het geoptimaliseerde plan.

Evenzo vragen mensen zich af waarom opgeslagen procedures sneller zijn dan functies?

Opgeslagen procedures kan zijn snel , heel snel , omdat ze voorgecompileerd zijn. De optimizer hoeft niet elke keer het uitvoeringsplan uit te werken. EEN Opgeslagen procedure zal resultaten retourneren in een tabelvorm. Functies kan Scalair zijn (een enkel resultaat retourneren) of tabelgegevens retourneren.

Bovendien, hoe is de opgeslagen procedure sneller dan de query? " Opgeslagen procedures zijn voorgecompileerd en in de cache opgeslagen, dus de prestaties zijn veel beter ." Opgeslagen procedures zijn voorgecompileerd en geoptimaliseerd, wat betekent dat de vraag motor kan ze sneller uitvoeren. Daarentegen, vragen in code moet tijdens runtime worden geparseerd, gecompileerd en geoptimaliseerd. Dit kost allemaal tijd.

Ook om te weten is, verhoogt de opgeslagen procedure de prestaties?

Herbruikbaarheid van queryplannen in cache Opgeslagen procedures verbeteren database uitvoering omdat ze het mogelijk maken om queryplannen in de cache opnieuw te gebruiken. Bij afwezigheid van geparametriseerde queryplannen, detecteert SQL Server automatisch parameters en genereert deze in de cache opgeslagen queryplannen, wat resulteert in: verbeterde prestatie.

Waarom opgeslagen procedures gebruiken?

EEN opgeslagen procedure biedt een belangrijke beveiligingslaag tussen de gebruikersinterface en de database. Het ondersteunt beveiliging door middel van gegevenstoegangscontroles omdat eindgebruikers gegevens kunnen invoeren of wijzigen, maar niet schrijven procedures . Het verbetert de productiviteit omdat uitspraken in a opgeslagen procedure hoeft maar één keer te worden geschreven.