FIX: Messaggio di errore quando si utilizza una funzione con valori di tabella (TVF) insieme con l'operatore CROSS APPLY in una query di SQL Server 2005: "È stato rilevato memoria di sistema insufficiente per eseguire la query"

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.

924954
Questo articolo è stato archiviato. L’articolo, quindi, viene offerto “così come è” e non verrà più aggiornato.
Bug #: 50000224 (SQL Hotfix)
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.
Sommario
Questo articolo viene descritto il seguente su questa versione di aggiornamento rapido (hotfix):
  • I problemi risolti dal pacchetto di aggiornamento rapido (hotfix)
  • Prerequisiti per l'applicazione del pacchetto hotfix
  • Se è necessario riavviare il computer dopo avere applicato il pacchetto di aggiornamento rapido (hotfix)
  • Se il pacchetto di hotfix è sostituito da qualsiasi altri pacchetti di aggiornamento rapido (hotfix)
  • Se è necessario apportare eventuali modifiche del Registro di sistema dopo avere applicato l'hotfix
  • I file contenuti nel pacchetto di aggiornamenti rapidi (hotfix)
Sintomi
Si consideri lo scenario seguente. In Microsoft SQL Server 2005, è possibile utilizzare una funzione con valori di tabella (TVF) insieme all'operatore CROSS APPLY in una query. È possibile utilizzare una TVF Transact-SQL o common language runtime (CLR) TVF. In questa situazione è possibile che venga visualizzato un messaggio d'errore simile al seguente:
Msg 701, livello 17, stato 123, 2
Memoria di sistema insufficienti per eseguire la query è.
Questo problema si verifica in genere, se la tabella sul lato sinistro della query produce molte righe.
Cause
Questo problema si verifica perché la memoria utilizzata per i parametri della TVF non viene rilasciata fino al completamento della query in esecuzione. Quando si utilizza una TVF insieme all'operatore CROSS APPLY, la TVF può essere chiamato più volte anche quando la query viene eseguita una sola volta. Quando la TVF viene chiamato più volte, l'utilizzo di grandi quantità di memoria.
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: 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

  • Microsoft SQL Server 2005 Service Pack 1 (SP1)

    Per informazioni su come ottenere SQL Server 2005 SP1, 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 una volta applicato l'hotfix.

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 siano 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, con le versioni a 32 bit
Nome del fileVersione del fileDimensione del fileDataOraPiattaforma
Logread.exe2005.90.2192.0398,11219-Set-200615: 10x 86
Microsoft.AnalysisServices.adomdclient.dll9.0.2192.0543,52019-Set-200615: 11x 86
Microsoft.AnalysisServices.deploymentengine.dll9.0.2192.0138,01619-Set-200615: 09x 86
Microsoft.AnalysisServices.dll9.0.2192.01,215,26419-Set-200615: 10x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2192.075,55219-Set-200615: 08x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2192.0908,06419-Set-200615: 10x 86
Msgprox.dll2005.90.2192.0197,92019-Set-200615: 09x 86
Msmdlocal.dll9.0.2192.015,609,63219-Set-200615: 11x 86
Msmdredir.dll9.0.2192.03,990,30419-Set-200615: 11x 86
Replprov.dll2005.90.2192.0547,61619-Set-200615: 11x 86
Replrec.dll2005.90.2192.0782,11219-Set-200615: 10x 86
Sqlaccess.dll2005.90.2192.0347,93619-Set-200615: 10x 86
Sqlagent90.exe2005.90.2192.0319,26419-Set-200615: 10x 86
Sqlservr.exe2005.90.2192.028,962,13619-Set-200615: 12x 86
Xpstar90.dll2005.90.2192.0292,64019-Set-200614: 02x 86
Xpstar90.rll2005.90.2192.0152,86419-Set-200615: 10x 86
SQL Server 2005, versione 64 x
Nome del fileVersione del fileDimensione del fileDataOraPiattaforma
Logread.exe2005.90.2192.0522,52819-Set-200614: 23x 64
Microsoft.AnalysisServices.adomdclient.dll9.0.2192.0543,52019-Set-200614: 23x 86
Microsoft.AnalysisServices.adomdclient.dll9.0.2192.0543,52019-Set-200615: 11x 86
Microsoft.AnalysisServices.deploymentengine.dll9.0.2192.0138,01619-Set-200615: 09x 86
Microsoft.AnalysisServices.dll9.0.2192.01,215,26419-Set-200615: 10x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2192.091,42419-Set-200614: 21x 64
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2192.075,55219-Set-200615: 08x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2192.0875,29619-Set-200614: 20x 86
Msgprox.dll2005.90.2192.0259,36019-Set-200614: 22x 64
Msmdlocal.dll9.0.2192.015,609,63219-Set-200615: 11x 86
Msmdredir.dll9.0.2192.03,990,30419-Set-200615: 11x 86
Replprov.dll2005.90.2192.0745,24819-Set-200614: 20x 64
Replrec.dll2005.90.2192.01,008,41619-Set-200614: 21x 64
Sqlaccess.dll2005.90.2192.0355,10419-Set-200614: 23x 86
Sqlagent90.exe2005.90.2192.0390,94419-Set-200614: 23x 64
Sqlservr.exe2005.90.2192.039,350,04819-Set-200614: 21x 64
Xpstar90.dll2005.90.2192.0540,96019-Set-200614: 23x 64
Xpstar90.rll2005.90.2192.0153,37619-Set-200614: 21x 64
SQL Server 2005, versione per l'architettura Itanium
Nome del fileVersione del fileDimensione del fileDataOraPiattaforma
Logread.exe2005.90.2192.01,095,45619-Set-200613: 52IA-64
Microsoft.AnalysisServices.adomdclient.dll9.0.2192.0543,52019-Set-200613: 51x 86
Microsoft.AnalysisServices.adomdclient.dll9.0.2192.0543,52019-Set-200615: 11x 86
Microsoft.AnalysisServices.deploymentengine.dll9.0.2192.0138,01619-Set-200615: 09x 86
Microsoft.AnalysisServices.dll9.0.2192.01,215,26419-Set-200615: 10x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2192.0163,10419-Set-200613: 50IA-64
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2192.075,55219-Set-200615: 08x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2192.0875,29619-Set-200613: 52x 86
Msgprox.dll2005.90.2192.0542,49619-Set-200613: 51IA-64
Msmdlocal.dll9.0.2192.048,585,50419-Set-200613: 53IA-64
Msmdredir.dll9.0.2192.06,237,47219-Set-200613: 53IA-64
Replprov.dll2005.90.2192.01,617,18419-Set-200613: 52IA-64
Replrec.dll2005.90.2192.02,141,47219-Set-200613: 52IA-64
Sqlaccess.dll2005.90.2192.0349,47219-Set-200613: 51x 86
Sqlagent90.exe2005.90.2192.01,143,58419-Set-200613: 52IA-64
Sqlservr.exe2005.90.2192.072,233,76019-Set-200613: 53IA-64
Xpstar90.dll2005.90.2192.0951,07219-Set-200613: 51IA-64
Xpstar90.rll2005.90.2192.0152,35219-Set-200613: 50IA-64
Status
Microsoft ha confermato che questo problema riguarda i prodotti sono elencati nella sezione "Si applica a".
Informazioni
Quando si esegue la query Transact-SQL, è possibile notare che i seguenti elementi aumentano gradualmente fino a che si verifica l'errore 701:
  • L'impiegato di memoria CACHESTORE_SQLCP da sys.dm_os_memory_clerks vista di gestione sistema di SQL Server
  • L'oggetto memoria MEMOBJ_XSTMT sys.dm_os_memory_objects vista di gestione sistema di SQL Server
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

Procedura per riprodurre il problema

  1. Per riprodurre il problema più veloce, è necessario configurare SQL Server 2005 per utilizzare una piccola quantità di memoria. A tale scopo, eseguire lo script seguente in SQL Server 2005.
    -- Enable advanced optionsUSE masterEXEC sp_configure 'show advanced options', 1goRECONFIGURE WITH OVERRIDEgo-- Set the maximum amount of memory to 300 MBexec sp_configure 'max server memory', 300goreconfigure with overridegodbcc freeproccachego
  2. Per interrompere e riavviare il servizio SQL Server, eseguire i seguenti comandi al prompt dei comandi di:
    net stop mssqlserver
    net start mssqlserver
  3. In SQL Server 2005, è necessario eseguire le seguenti istruzioni Transact-SQL.
    drop table tgocreate table t (c1 int, c2 int, c3 int, c4 int, c5 int, c6 int, c7 int, c8 int, c9 int, c10 int)godrop function fn_testgocreate function fn_test (@p1 int, @p2 int, @p3 int, @p4 int, @p5 int, @p6 int, @p7 int, @p8 int, @p9 int, @p10 int)returns @t table (c1 nvarchar(4) )with schemabindingasbegininsert into @t values (N'abcd')returnendgodrop function fn_scalargocreate function fn_scalar (@p1 int, @p2 int, @p3 int, @p4 int, @p5 int, @p6 int, @p7 int, @p8 int, @p9 int, @p10 int)returns nvarchar(4) with schemabindingasbegindeclare @s nvarchar (4)set @s = N'abcd' return @sendgodrop function fn_test2gocreate function fn_test2 ()returns @t table (c1 nvarchar(4) )with schemabindingasbegininsert into @t values (N'abcd')returnendgoset nocount ongodeclare @i intset @i = 0while @i < 5000000begininsert into t values (@i, @i, @i, @i, @i, @i, @i, @i, @i, @i)set @i = @i + 1endgo-- The following select query returns the 701 error if you restrict max server memory to 300 MBselect count(*) from t cross apply dbo.fn_test(c1,c2,c3,c4,c5,c6,c7,c8,c9,c10)
Nota Queste procedure vengono utilizzati una TVF Transact-SQL. Questo problema si verifica anche quando si utilizza una TVF CLR.

Avviso: questo articolo è stato tradotto automaticamente

Proprietà

ID articolo: 924954 - Ultima revisione: 01/17/2015 16:08:38 - Revisione: 1.6

  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition
  • kbnosurvey kbarchive kbmt kbautohotfix kbfix kbsql2005tsql kbexpertiseadvanced kbhotfixserver kbqfe kbpubtypekc KB924954 KbMtit
Feedback