FIX: Le prestazioni del sistema potrebbero risultare insoddisfacenti quando un'applicazione invia molte query in un database SQL Server 2005 che utilizza la parametrizzazione semplice

Traduzione articoli Traduzione articoli
Identificativo articolo: 920206 - Visualizza i prodotti a cui si riferisce l?articolo.
Microsoft distribuisce le correzioni di Microsoft SQL Server 2005 come un unico file scaricabile. Poiché le correzioni sono cumulative, ogni nuova versione contiene tutti gli aggiornamenti rapidi e tutte le correzioni protezione rilasciate con SQL Server 2005 precedente versione di correzione.
Espandi tutto | Chiudi tutto

In questa pagina

Sommario

Questo articolo viene descritto il seguente su questa versione di aggiornamento rapido (hotfix):
  • I problemi risolti da questo pacchetto di aggiornamento rapido (hotfix)
  • Prerequisiti per l'installazione del pacchetto hotfix
  • Se è necessario riavviare il computer dopo l'installazione del pacchetto di aggiornamento rapido (hotfix)
  • Se il pacchetto di hotfix è sostituito da qualsiasi altri pacchetti di aggiornamento rapido (hotfix)
  • Se è necessario apportare modifiche del Registro di sistema
  • I file contenuti nel pacchetto di aggiornamenti rapidi (hotfix)

Sintomi

Si consideri il seguente scenario: un'applicazione invia molte query in un database di Microsoft SQL Server 2005. Le query di testo di query identiche e dichiarare gli stessi parametri. Tuttavia, le query avere diverse combinazioni di precisione e scala per i valori del tipo di dati numerico nella stringa di dichiarazione di parametro. Il database di SQL Server 2005 utilizza parametrizzazione semplice. In questo scenario, le prestazioni del sistema SQL Server 2005 potrebbero essere lenta. Inoltre, potrebbero verificarsi utilizzo elevato della CPU.

Questo problema si verifica più frequentemente quando il database di SQL Server 2005 è di grandi dimensioni ed è in uno scenario di alta sollecitazione.

Nota Il comportamento predefinito di un database di SQL Server 2005 consiste nell'utilizzare semplici parametrizzazione.

Cause

Questo problema si verifica perché SQL Server è necessario esaminare tutte le query per trovare una query che è una corrispondenza per il testo della query, i parametri e la stringa di dichiarazione del parametro.

Risoluzione

Informazioni sull'hotfix

È disponibile un hotfix supportato. Questo hotfix è tuttavia destinato esclusivamente alla risoluzione del problema descritto in questo articolo. Consente di applicare questo aggiornamento rapido (hotfix) solo ai sistemi in cui si verifica questo problema specifico. Questo aggiornamento rapido (hotfix) potrebbe essere eseguiti ulteriori test. Se non si è notevolmente interessati da questo problema, si consiglia pertanto di attendere il successivo aggiornamento di software che contiene questo aggiornamento rapido (hotfix).

Se l'hotfix è disponibile per il download, è una sezione "Hotfix disponibile per il download" all'inizio di questo articolo della Knowledge Base. Se non viene visualizzato in questa sezione, è necessario contattare servizio clienti Microsoft e supporto tecnico per ottenere l'hotfix.

Nota Se si verificano ulteriori problemi o se la risoluzione dei problemi è necessario, potrebbe essere necessario creare una richiesta di servizio separato. I costi di supporto normale verranno applicati per eventuali ulteriori domande e problemi che non dovessero rientrare nello specifico hotfix in questione. Per un elenco completo, di Microsoft Customer Service and Support numeri di telefono o a creare una richiesta di servizio distinto, visitare il seguente sito Web Microsoft:
http://support.microsoft.com/contactus/?ws=support
Nota Il modulo "Hotfix disponibile per il download" Visualizza le lingue per cui è disponibile l'aggiornamento rapido. Se non viene visualizzata la lingua, è perché un aggiornamento rapido (hotfix) non è disponibile per tale lingua.

Prerequisiti

Per applicare questo aggiornamento rapido (hotfix), è necessario SQL Server 2005 Service Pack 1 (SP1) installato nel computer.
Per ulteriori informazioni su come ottenere SQL Server 2005 Service Pack 1, fare clic sul numero dell'articolo della Microsoft Knowledge Base riportato di seguito riportato:
913089Come ottenere il service pack più recente per SQL Server 2005

Informazioni sul riavvio

Non è necessario riavviare il computer dopo avere applicato questo aggiornamento rapido (hotfix).

Informazioni del Registro di sistema

Non è necessario modificare il Registro di sistema.

Informazioni sulla sostituzione della correzione

Questo aggiornamento rapido (hotfix) non sostituisce eventuali altri hotfix.

Informazioni sul file di hotfix

Questo aggiornamento rapido (hotfix) contiene solo i file necessari per correggere i problemi elencati nel presente articolo. Questo aggiornamento rapido (hotfix) non può contenere di tutti i file necessari per aggiornare completamente un prodotto all'ultima build.
La versione di lingua inglese di questo aggiornamento rapido (hotfix) presenta gli attributi di file (o attributi successivi) elencati nella tabella riportata di seguito. Le date e le ore per questi file sono indicati in UTC (Coordinated Universal Time). Quando si visualizzano le informazioni sul file, viene convertito in ora locale. Per calcolare la differenza tra ora UTC e l'ora locale, utilizzare la scheda fuso orario dello data e ora nel Pannello di controllo.
hotfix di SQL Server 2005 a 32 bit
Riduci questa tabellaEspandi questa tabella
Nome del fileVersione del fileDimensione del fileDataOraPiattaforma
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.075,55214-Giu-200620: 29x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2164.0908,06414-Giu-200620: 32x 86
Msgprox.dll2005.90.2164.0197,92014-Giu-200620: 29x 86
Msmdlocal.dll9.0.2164.015,661,85614-Giu-200620: 33x 86
Mssqlsystemresource.ldfNon applicabile524.28814-Giu-200614: 23Non applicabile
Mssqlsystemresource.mdfNon applicabile39,911,42414-Giu-200614: 23Non applicabile
Replprov.dll2005.90.2164.0547,61614-Giu-200620: 31x 86
Replrec.dll2005.90.2164.0782,11214-Giu-200620: 32x 86
Sqlaccess.dll2005.90.2164.0347,93614-Giu-200620: 31x 86
Sqlservr.exe2005.90.2164.028,950,87214-Giu-200620: 33x 86
hotfix di SQL Server 2005, a 64 bit
Riduci questa tabellaEspandi questa tabella
Nome del fileVersione del fileDimensione del fileDataOraPiattaforma
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.075,55214-Giu-200620: 29x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.091,42414-Giu-200621: 10x 64
Microsoft.SqlServer.SqlEnum.dll9.0.2164.0875,29614-Giu-200621: 12x 86
Msgprox.dll2005.90.2164.0259,36014-Giu-200621: 10x 64
Msmdlocal.dll9.0.2164.015,661,85614-Giu-200620: 33x 86
Mssqlsystemresource.ldfNon applicabile524.28814-Giu-200614: 23Non applicabile
Mssqlsystemresource.mdfNon applicabile39,911,42414-Giu-200614: 23Non applicabile
Replprov.dll2005.90.2164.0745,24814-Giu-200621: 12x 64
Replrec.dll2005.90.2164.01,008,41614-Giu-200621: 12x 64
Sqlaccess.dll2005.90.2164.0355,10414-Giu-200621: 11x 86
Sqlservr.exe2005.90.2164.039,251,23214-Giu-200621: 13x 64
hotfix di SQL Server 2005, per processori Itanium a 64 bit
Riduci questa tabellaEspandi questa tabella
Nome del fileVersione del fileDimensione del fileDataOraPiattaforma
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.0163,10414-Giu-200620: 29IA-64
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.075,55214-Giu-200620: 29x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2164.0875,29614-Giu-200620: 29x 86
Msgprox.dll2005.90.2164.0542,49614-Giu-200620: 28IA-64
Msmdlocal.dll9.0.2164.048,733,98414-Giu-200620: 30IA-64
Mssqlsystemresource.ldfNon applicabile524.28814-Giu-200614: 23Non applicabile
Mssqlsystemresource.mdfNon applicabile39,911,42414-Giu-200614: 23Non applicabile
Replprov.dll2005.90.2164.01,617,18414-Giu-200620: 29IA-64
Replrec.dll2005.90.2164.02,141,47214-Giu-200620: 29IA-64
Sqlaccess.dll2005.90.2164.0349,47214-Giu-200620: 28x 86
Sqlservr.exe2005.90.2164.072,208,67214-Giu-200620: 30IA-64

Status

Microsoft ha confermato che questo problema riguarda i prodotti sono elencati nella sezione "Si applica a".

Workaround

Per risolvere questo problema, scegliere la parametrizzazione esplicito nell'applicazione client. Quando si utilizza parametrizzazione esplicito nell'applicazione client, piano di unica esecuzione viene creato e memorizzato nella cache delle procedure. In questa soluzione, le prestazioni del sistema SQL Server 2005 viene eseguito come previsto.

Per ulteriori informazioni su parametrizzazione esplicita e piano di esecuzione riutilizzare, visitare il seguente sito Web MSDN (informazioni in lingua inglese):
http://msdn2.microsoft.com/en-us/library/ms175580.aspx

Informazioni

Quando un'applicazione invia molte query in un database di SQL Server 2005, il piano di esecuzione per ogni query deve essere presente nella cache delle procedure prima dell'esecuzione di query.

Nota Se il piano di esecuzione per una query specifica non è presente nella cache delle procedure, SQL Server compila la query, scrive il piano di esecuzione per la query di cache delle procedure e quindi esegue la query.

Quando SQL Server 2005 recupera un piano memorizzato nella cache per una specifica query dalla cache delle procedure, SQL Server identifica il piano di esecuzione corrispondente utilizzando una chiave hash che è stata derivata quando la query è stata compilata. La versione originale di SQL Server 2005 deriva chiavi hash da solo il testo della query e passa la stringa di dichiarazione del parametro. Quando SQL Server 2005 deriva chiavi hash da solo il testo della query, SQL Server 2005 inserisce chiavi hash per tutte le query contenenti testo della query identici e gli stessi parametri nel bucket stesso hash. Questo comportamento si verifica anche se ciascuna query dispone di una combinazione diversa di precisione e scala per i valori numerici nella stringa di dichiarazione di parametro. SQL Server 2005 tenta di recuperare un piano di esecuzione di query memorizzati nella cache dalla cache delle procedure per una query specifica, SQL Server deve analizzare tutti i query piani di esecuzione nel bucket hash corrispondente per trovare il piano di esecuzione una query che corrisponde al testo della query, i parametri e la stringa di dichiarazione del parametro.

Dopo avere applicato questo aggiornamento rapido (hotfix), SQL Server 2005 deriva chiavi hash dal testo della query e la stringa di dichiarazione del parametro. Quando una nuova query dispone di una combinazione di precisione e scala per i valori numerici nella stringa di dichiarazione di parametro non corrisponde a un'altra query esistente, SQL Server 2005 inserisce la chiave hash per la nuova query in un nuovo bucket di hash. SQL Server 2005 inserisce la chiave hash per la nuova query in un nuovo bucket di hash, anche quando la nuova query dispone di testo della query identici e gli stessi parametri query esistente di un altro. Di conseguenza, quando SQL Server 2005 tenta di recuperare i piani di esecuzione memorizzato nella cache dalla cache delle procedure per la nuova query, la funzione il bucket hash corrispondente contiene solo una query per SQL Server esaminare.

In questo scenario la risoluzione di aggiornamento rapido (hotfix), SQL Server 2005 presenta ancora molti piani di esecuzione. Questo si verifica perché un piano di esecuzione separato viene creato per ogni query che presenta una nuova combinazione di precisione e scala per i valori numerici nella stringa di dichiarazione di parametro. Ogni piano di esecuzione richiede risorse di sistema di SQL Server 2005 per creare il piano di esecuzione. Ogni piano di esecuzione richiede risorse di sistema di SQL Server 2005 per memorizzare il piano di esecuzione nella cache delle procedure. Poiché lo scenario di risoluzione di aggiornamento rapido (hotfix) richiede numerose risorse di sistema di SQL Server 2005, le prestazioni del sistema SQL Server 2005 potrebbero essere comunque più lenta del previsto.
Per ulteriori informazioni, fare clic sul numero dell'articolo della Microsoft Knowledge Base riportato di seguito riportato:
824684Descrizione della terminologia standard utilizzata per descrivere gli aggiornamenti software Microsoft

Proprietà

Identificativo articolo: 920206 - Ultima modifica: martedì 20 novembre 2007 - Revisione: 1.8
Le informazioni in questo articolo si applicano a:
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Developer Edition
Chiavi: 
kbmt kbautohotfix kbbug kbfix kbtshoot kbhotfixserver kbqfe kbpubtypekc KB920206 KbMtit
Traduzione automatica articoli
Il presente articolo è stato tradotto tramite il software di traduzione automatica di Microsoft e non da una persona. Microsoft offre sia articoli tradotti da persone fisiche sia articoli tradotti automaticamente da un software, in modo da rendere disponibili tutti gli articoli presenti nella nostra Knowledge Base nella lingua madre dell?utente. Tuttavia, un articolo tradotto in modo automatico non è sempre perfetto. Potrebbe contenere errori di sintassi, di grammatica o di utilizzo dei vocaboli, più o meno allo stesso modo di come una persona straniera potrebbe commettere degli errori parlando una lingua che non è la sua. Microsoft non è responsabile di alcuna imprecisione, errore o danno cagionato da qualsiasi traduzione non corretta dei contenuti o dell?utilizzo degli stessi fatto dai propri clienti. Microsoft, inoltre, aggiorna frequentemente il software di traduzione automatica.
Clicca qui per visualizzare la versione originale in inglese dell?articolo: 920206
LE INFORMAZIONI CONTENUTE NELLA MICROSOFT KNOWLEDGE BASE SONO FORNITE SENZA GARANZIA DI ALCUN TIPO, IMPLICITA OD ESPLICITA, COMPRESA QUELLA RIGUARDO ALLA COMMERCIALIZZAZIONE E/O COMPATIBILITA' IN IMPIEGHI PARTICOLARI. L'UTENTE SI ASSUME L'INTERA RESPONSABILITA' PER L'UTILIZZO DI QUESTE INFORMAZIONI. IN NESSUN CASO MICROSOFT CORPORATION E I SUOI FORNITORI SI RENDONO RESPONSABILI PER DANNI DIRETTI, INDIRETTI O ACCIDENTALI CHE POSSANO PROVOCARE PERDITA DI DENARO O DI DATI, ANCHE SE MICROSOFT O I SUOI FORNITORI FOSSERO STATI AVVISATI. IL DOCUMENTO PUO' ESSERE COPIATO E DISTRIBUITO ALLE SEGUENTI CONDIZIONI: 1) IL TESTO DEVE ESSERE COPIATO INTEGRALMENTE E TUTTE LE PAGINE DEVONO ESSERE INCLUSE. 2) I PROGRAMMI SE PRESENTI, DEVONO ESSERE COPIATI SENZA MODIFICHE, 3) IL DOCUMENTO DEVE ESSERE DISTRIBUITO INTERAMENTE IN OGNI SUA PARTE. 4) IL DOCUMENTO NON PUO' ESSERE DISTRIBUITO A SCOPO DI LUCRO.

Invia suggerimenti

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com