FIX: Utilizzo di memoria del piano di query compilata pu˛ aumentare in modo imprevisto in SQL Server 2005

Traduzione articoli Traduzione articoli
Identificativo articolo: 919636 - Visualizza i prodotti a cui si riferisce l?articolo.
Bug #: 810 (SQL Hotfix)
Avviso
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
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
  • Informazioni se Ŕ necessario riavviare il computer dopo l'installazione del pacchetto di aggiornamento rapido (hotfix)
  • Informazioni sulla sostituzione del pacchetto hotfix da qualsiasi altro pacchetto di aggiornamento rapido (hotfix)
  • Informazioni sulla necessitÓ di apportare le modifiche del Registro di sistema
  • I file contenuti nel pacchetto di aggiornamenti rapidi (hotfix)

Sintomi

Quando si esamina il piano di query compilata di una query, Ŕ possibile notare che l'utilizzo della memoria del piano di query compilati pu˛ aumentare in modo imprevisto in SQL Server 2005 rispetto a Microsoft SQL Server 2000.

Questo problema pu˛ verificarsi quando una delle seguenti condizioni Ŕ true:
  • condizione 1: La query di fa riferimento a una tabella che utilizza colonne calcolate.
  • condizione 2: La query contiene le operazioni di stringa tra i valori delle colonne nvarchar e stringhe ANSI. Ad esempio, l'operazione di stringa confronta i valori delle colonne nvarchar stringhe ANSI.
  • condizione 3: La query contiene un riferimento a una tabella contenente una colonna calcolata. La colonna calcolata dipende da una colonna nvarchar . Tuttavia, la colonna computer utilizza costanti di stringa ANSI nell'espressione.
Condizioni 2 e 3 possono determinare la un aumento significativo nell'utilizzo della memoria di un piano query compilata.

Ad esempio, Ŕ necessario che una tabella contenente una colonna nvarchar . Il nome della tabella Ŕ di tabella e il nome della colonna nvarchar Ŕ MyCol. Quindi Ŕ possibile definire la query utilizzando la seguente sintassi:
SELECT CASE MyCol
          WHEN 'Value1' THEN 'NewValue1'
          WHEN 'Value2' THEN 'NewValue2'
          ELSE MyCol
       END
FROM MyTable
in questo esempio, le stringhe "Valore1", "Valore2", "NewValue1" e "NewValue2" sono stringhe ANSI. I valori della colonna nvarchar MyCol vengono innanzitutto confrontati con le stringhe ANSI "Valore1" e "Value2". Quindi, il valore corrispondente del "NewValue1", "NewValue2" stringa ANSI o il valore originale della colonna MyCol viene scelto.

╚ possibile visualizzare l'utilizzo della memoria piano compilato esaminando la colonna di tabella sistema sys.syscacheobjects o la visualizzazione di gestione dinamica sys.dm_exec_cached_plans pagesused .

Questa maggiore dimensione del piano di query compilati pu˛ inoltre causare un aumento del tempo di attesa per il tipo di attesa RESOURCE_SEMAPHORE_QUERY_COMPILE.

Risoluzione

╚ 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

╚ necessario SQL Server 2005 Service Pack 1 (SP1) per applicare questo aggiornamento rapido (hotfix). 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). Tuttavia, se giÓ Ŕ interessato dal problema, attenersi alla procedura nella sezione "Workground" dopo aver applicato questo hotfix per ripristinare i file di database a uno stato integro.

Informazioni del Registro di sistema

Non Ŕ necessario modificare il Registro di sistema.

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.
SQL Server 2005 a 32 bit
Riduci questa tabellaEspandi questa tabella
Nome del fileVersione del fileDimensione del fileDataOraPiattaforma
Microsoft.SqlServer.SqlEnum.dll9.0.2164.0908,06414-Giu-200612: 32x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.075,55214-Giu-200612: 29x 86
Msgprox.dll2005.90.2164.0197,92014-Giu-200612: 29x 86
Replprov.dll2005.90.2164.0547,61614-Giu-200612: 31x 86
Replrec.dll2005.90.2164.0782,11214-Giu-200612: 32x 86
Msmdlocal.dll9.0.2164.015,661,85614-Giu-200612: 33x 86
Sqlaccess.dll2005.90.2164.0347,93614-Giu-200612: 31x 86
Sqlservr.exe2005.90.2164.028,950,87214-Giu-200612: 33x 86
Versione SQL Server 2005 x 64
Riduci questa tabellaEspandi questa tabella
Nome del fileVersione del fileDimensione del fileDataOraPiattaforma
Microsoft.SqlServer.SqlEnum.dll9.0.2164.0875,29614-Giu-200613: 12x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.091,42414-Giu-200612: 29x 64
Msgprox.dll2005.90.2164.0259,36014-Giu-200613: 10x 64
Replprov.dll2005.90.2164.0745,24814-Giu-200613: 12x 64
Replrec.dll2005.90.2164.01,008,41614-Giu-200613: 12x 64
Msmdlocal.dll9.0.2164.015,661,85614-Giu-200612: 33x 86
Sqlaccess.dll2005.90.2164.0355,10414-Giu-200613: 11x 86
Sqlservr.exe2005.90.2164.039,251,23214-Giu-200613: 13x 64
Versione per l'architettura Itanium di SQL Server 2005
Riduci questa tabellaEspandi questa tabella
Nome del fileVersione del fileDimensione del fileDataOraPiattaforma
Microsoft.SqlServer.SqlEnum.dll9.0.2164.0875,29614-Giu-200612: 29x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2164.0163,10414-Giu-200612: 29IA-64
Msgprox.dll2005.90.2164.0542,49614-Giu-200612: 28IA-64
Msmdlocal.dll9.0.2164.048,733,98414-Giu-200612: 30IA-64
Replprov.dll2005.90.2164.01,617,18414-Giu-200612: 29IA-64
Replrec.dll2005.90.2164.02,141,47214-Giu-200612: 29IA-64
Sqlaccess.dll2005.90.2164.0349,47214-Giu-200612: 28x 86
Sqlservr.exe2005.90.2164.072,208,67214-Giu-200612: 30IA-64

Workaround

Per risolvere questo problema, aggiungere una lettera maiuscola, "N" davanti a tutte le stringhe presenti il contesto del problema. ╚ possibile modificare l'esempio Ŕ descritto nella sezione "Sintomi" utilizzando la seguente sintassi:

SELECT CASE MyCol WHEN N'Value1' THEN N'NewValue1' WHEN N'Value2' THEN N'NewValue2' ELSE MyCol END FROM MyTable

Status

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

Informazioni

╚ possibile visualizzare l'utilizzo della memoria piano compilato esaminando la colonna di tabella sistema sys.syscacheobjects o la visualizzazione di gestione dinamica sys.dm_exec_cached_plans pagesused .

Per ulteriori informazioni sulla tabella di sistema sys.syscacheobjects, visitare il seguente sito Web MSDN (informazioni in lingua inglese):
http://msdn2.microsoft.com/en-us/library/ms187815.aspx
Per ulteriori informazioni sulla visualizzazione di gestione dinamica sys.dm_exec_cached_plans, visitare il seguente sito Web MSDN:
http://msdn.microsoft.com/en-us/library/ms187404.aspx
Per ulteriori informazioni sullo schema di denominazione degli aggiornamenti di Microsoft SQL Server, fare clic sul numero dell'articolo della Microsoft Knowledge Base riportato di seguito riportato:
822499Nuovo schema di denominazione per i pacchetti di aggiornamento software di Microsoft SQL Server
Per ulteriori informazioni sulla terminologia di aggiornamento software, 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: 919636 - Ultima modifica: martedý 20 novembre 2007 - Revisione: 1.9
Le informazioni in questo articolo si applicano a:
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Workgroup Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Standard X64 Edition
Chiavi:á
kbmt kbautohotfix kbsql2005engine kbhotfixserver kbexpertiseadvanced kbqfe kbfix kbpubtypekc KB919636 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: 919636
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