CORRECTIF : message d'erreur lorsque vous utilisez une fonction table (TVF) et avec l'opérateur CROSS s'appliquent dans une requête dans SQL Server 2005: « système insuffisantes mémoire est pour exécuter cette requête »

Traductions disponibles Traductions disponibles
Numéro d'article: 924954 - Voir les produits auxquels s'applique cet article
Bogue #: 50000224 (correctifs SQL)
Microsoft distribue les correctifs Microsoft SQL Server 2005 le biais comme un fichier téléchargeable. Les correctifs étant cumulatifs, chaque nouvelle version contient tous les correctifs et tous les correctifs de sécurité qui étaient fournis avec la précédente SQL Server 2005 version du correctif.
Agrandir tout | Réduire tout

Sommaire

Résumé

Cet article décrit suivants concernant cette version de correctif logiciel :
  • Les problèmes qui sont résolus par le package de correctifs
  • Les conditions requises pour appliquer le package de correctifs
  • Si vous devez redémarrer l'ordinateur après avoir appliqué le package de correctifs
  • Si le package de correctifs est remplacé par un autre package de correctif
  • Si vous devez apporter les modifications Registre après avoir appliqué le package de correctifs
  • Les fichiers qui sont contenus dans le package de correctifs

Symptômes

Envisagez le scénario suivant. Dans Microsoft SQL Server 2005, vous utilisez une fonction table (TVF) avec l'opérateur CROSS s'appliquent dans une requête. Vous utilisez une TVF Transact-SQL ou un common language runtime (CLR) TVF. Dans ce scénario, le message d'erreur suivant peut s'afficher :
Msg 701, niveau 17, état 123, ligne 2
Mémoire système insuffisantes pour exécuter cette requête est.
En règle générale, vous rencontrez ce problème si la table du côté gauche de la requête génère grand nombre de lignes.

Cause

Ce problème se produit car la mémoire est utilisée pour les paramètres de la TVF n'est pas libérée jusqu'à ce que la requête a terminé l'exécution. Lorsque vous utilisez une TVF et avec l'opérateur CROSS s'appliquent, la TVF peut-être être appelée plusieurs fois même lorsque la requête est exécutée une seule fois. Lorsque la TVF est appelée plusieurs fois, beaucoup de mémoire est consommée.

Résolution

Informations sur le correctif

Un correctif est disponible auprès de Microsoft. Toutefois, ce correctif est conçu pour corriger le problème décrit dans cet article. Appliquer ce correctif uniquement aux systèmes rencontrant ce problème spécifique. Ce correctif peut subir des tests supplémentaires. Par conséquent, si vous n'êtes pas gravement touché par ce problème, nous vous recommandons d'attendre la prochaine mise à jour logicielles qui contiendra ce correctif.

Si le correctif est disponible pour le téléchargement, il est une section « téléchargement correctif disponible » en haut de cet article de la base de connaissances. Si cette section n'apparaît pas, contactez le service clientèle Microsoft et de support pour obtenir le correctif.

note Si des problèmes supplémentaires se produisent ou si n'importe quel dépannage est nécessaire, vous devrez peut-être créer une demande de service distincte. Les coûts habituels du support technique s'appliqueront aux autres questions et problèmes non traités par ce correctif spécifique. Pour une liste complète des Microsoft client service et support numéros de téléphone ou pour créer une demande de service distincte, reportez-vous au site de Web Microsoft suivant :
http://support.microsoft.com/contactus/?ws=support
note L'écran de « téléchargement correctif disponible » affiche les langues pour lesquelles le correctif est disponible. Si vous ne voyez pas la langue, il est car un correctif logiciel n'est pas disponible pour cette langue.

Conditions préalables

  • Microsoft SQL Server 2005 Service Pack 1 (SP1)

    Pour savoir comment obtenir SQL Server 2005 SP1, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
    913089 Comment obtenir le dernier pack service pour SQL Server 2005

Redémarrez les informations

Vous devez redémarrer l'ordinateur après avoir appliqué le correctif.

Informations de Registre

Vous devez modifier le Registre.

Informations sur le fichier de correctif

Ce correctif contient uniquement les fichiers nécessaires à la résolution des problèmes décrits dans cet article. Ce correctif peut ne pas contenir tous les fichiers nécessaires à la mise à jour complètement un produit vers la dernière version.

La version anglaise de ce correctif dispose les attributs de fichier (ou attributs de fichier version ultérieure) répertoriés dans le tableau suivant. Les dates et heures de ces fichiers sont exprimées en temps universel coordonné (UTC). Lorsque vous affichez les informations de fichier, il est convertie en heure locale. Pour connaître le décalage entre l'heure UTC et l'heure locale, utilisez l'onglet Fuseau horaire dans l'élément Date et heure du Panneau de configuration.
SQL Server 2005, versions 32 bits
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Logread.exe2005.90.2192.0398,11219-Sep-200615:10x 86
Microsoft.analysisservices.adomdclient.dll9.0.2192.0543,52019-Sep-200615:11x 86
Microsoft.analysisservices.deploymentengine.dll9.0.2192.0138,01619-Sep-200615:09x 86
Microsoft.analysisservices.dll9.0.2192.01,215,26419-Sep-200615:10x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2192.075,55219-Sep-200615:08x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2192.0908,06419-Sep-200615:10x 86
Msgprox.dll2005.90.2192.0197,92019-Sep-200615:09x 86
Msmdlocal.dll9.0.2192.015,609,63219-Sep-200615:11x 86
Msmdredir.dll9.0.2192.03,990,30419-Sep-200615:11x 86
Replprov.dll2005.90.2192.0547,61619-Sep-200615:11x 86
Replrec.dll2005.90.2192.0782,11219-Sep-200615:10x 86
Sqlaccess.dll2005.90.2192.0347,93619-Sep-200615:10x 86
Sqlagent90.exe2005.90.2192.0319,26419-Sep-200615:10x 86
Sqlservr.exe2005.90.2192.028,962,13619-Sep-200615:12x 86
Xpstar90.dll2005.90.2192.0292,64019-Sep-200614:02x 86
Xpstar90.rll2005.90.2192.0152,86419-Sep-200615:10x 86
SQL Server 2005, version x 64
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Logread.exe2005.90.2192.0522,52819-Sep-200614:23x 64
Microsoft.analysisservices.adomdclient.dll9.0.2192.0543,52019-Sep-200614:23x 86
Microsoft.analysisservices.adomdclient.dll9.0.2192.0543,52019-Sep-200615:11x 86
Microsoft.analysisservices.deploymentengine.dll9.0.2192.0138,01619-Sep-200615:09x 86
Microsoft.analysisservices.dll9.0.2192.01,215,26419-Sep-200615:10x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2192.091,42419-Sep-200614:21x 64
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2192.075,55219-Sep-200615:08x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2192.0875,29619-Sep-200614:20x 86
Msgprox.dll2005.90.2192.0259,36019-Sep-200614:22x 64
Msmdlocal.dll9.0.2192.015,609,63219-Sep-200615:11x 86
Msmdredir.dll9.0.2192.03,990,30419-Sep-200615:11x 86
Replprov.dll2005.90.2192.0745,24819-Sep-200614:20x 64
Replrec.dll2005.90.2192.01,008,41619-Sep-200614:21x 64
Sqlaccess.dll2005.90.2192.0355,10419-Sep-200614:23x 86
Sqlagent90.exe2005.90.2192.0390,94419-Sep-200614:23x 64
Sqlservr.exe2005.90.2192.039,350,04819-Sep-200614:21x 64
Xpstar90.dll2005.90.2192.0540,96019-Sep-200614:23x 64
Xpstar90.rll2005.90.2192.0153,37619-Sep-200614:21x 64
SQL Server 2005, version d'architecture Itanium
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Logread.exe2005.90.2192.01,095,45619-Sep-200613:52IA-64
Microsoft.analysisservices.adomdclient.dll9.0.2192.0543,52019-Sep-200613:51x 86
Microsoft.analysisservices.adomdclient.dll9.0.2192.0543,52019-Sep-200615:11x 86
Microsoft.analysisservices.deploymentengine.dll9.0.2192.0138,01619-Sep-200615:09x 86
Microsoft.analysisservices.dll9.0.2192.01,215,26419-Sep-200615:10x 86
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2192.0163,10419-Sep-200613:50IA-64
Microsoft.SqlServer.mgdsqldumper.dll2005.90.2192.075,55219-Sep-200615:08x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2192.0875,29619-Sep-200613:52x 86
Msgprox.dll2005.90.2192.0542,49619-Sep-200613:51IA-64
Msmdlocal.dll9.0.2192.048,585,50419-Sep-200613:53IA-64
Msmdredir.dll9.0.2192.06,237,47219-Sep-200613:53IA-64
Replprov.dll2005.90.2192.01,617,18419-Sep-200613:52IA-64
Replrec.dll2005.90.2192.02,141,47219-Sep-200613:52IA-64
Sqlaccess.dll2005.90.2192.0349,47219-Sep-200613:51x 86
Sqlagent90.exe2005.90.2192.01,143,58419-Sep-200613:52IA-64
Sqlservr.exe2005.90.2192.072,233,76019-Sep-200613:53IA-64
Xpstar90.dll2005.90.2192.0951,07219-Sep-200613:51IA-64
Xpstar90.rll2005.90.2192.0152,35219-Sep-200613:50IA-64

Statut

Microsoft a confirmé que c'est un problème dans les produits Microsoft répertoriés dans la section « S'applique à ».

Plus d'informations

Lorsque vous exécutez la requête Transact-SQL, vous remarquez que les éléments suivants augmenter progressivement jusqu'à ce que l'erreur 701 se produit :
  • L'employé de mémoire CACHESTORE_SQLCP de sys.dm_os_memory_clerks vue de gestion de système d'exploitation SQL Server
  • L'objet mémoire MEMOBJ_XSTMT sys.dm_os_memory_objects vue de gestion de système d'exploitation SQL Server
Pour plus d'informations, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
824684 Description de la terminologie standard utilisée pour décrire les mises à jour logicielles Microsoft

Procédure pour reproduire le problème

  1. Pour reproduire le problème plus rapidement, configurez SQL Server 2005 pour utiliser une petite quantité de mémoire. Pour ce faire, exécutez le script suivant dans SQL Server 2005.
    -- Enable advanced options
    USE master
    EXEC sp_configure 'show advanced options', 1
    go
    RECONFIGURE WITH OVERRIDE
    go
    
    -- Set the maximum amount of memory to 300 MB
    exec sp_configure 'max server memory', 300
    go
    reconfigure with override
    go
    dbcc freeproccache
    go
    
  2. Pour arrêter, puis redémarrez le service SQL Server, exécutez les commandes suivantes à partir d'une invite de commandes :
    net stop mssqlserver
    net start mssqlserver
  3. Dans SQL Server 2005, exécutez les instructions Transact-SQL suivantes.
    drop table t
    go
    create table t (c1 int, c2 int, c3 int, c4 int, c5 int, c6 int, c7 int, c8 int, c9 int, c10 int)
    go
    
    drop function fn_test
    go
    create 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 schemabinding
    as
    begin
    insert into @t values (N'abcd')
    return
    end
    go
    drop function fn_scalar
    go
    create 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 schemabinding
    as
    begin
    declare @s nvarchar (4)
    set @s = N'abcd' 
    
    return @s
    end
    
    go
    drop function fn_test2
    go
    create function fn_test2 ()
    returns @t table (c1 nvarchar(4) )
    with schemabinding
    as
    begin
    insert into @t values (N'abcd')
    return
    end
    
    
    go
    set nocount on
    go
    declare @i int
    set @i = 0
    while @i < 5000000
    begin
    insert into t values (@i, @i, @i, @i, @i, @i, @i, @i, @i, @i)
    set @i = @i + 1
    end
    
    go
    -- The following select query returns the 701 error if you restrict max server memory to 300 MB
    select count(*) from t cross apply dbo.fn_test(c1,c2,c3,c4,c5,c6,c7,c8,c9,c10)
    
    
note Ces étapes utilisent une TVF Transact-SQL. Ce problème se produit également lorsque vous utilisez une TVF CLR.

Propriétés

Numéro d'article: 924954 - Dernière mise à jour: mardi 20 novembre 2007 - Version: 1.6
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • 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
Mots-clés : 
kbmt kbautohotfix kbfix kbsql2005tsql kbexpertiseadvanced kbhotfixserver kbqfe kbpubtypekc KB924954 KbMtfr
Traduction automatique
IMPORTANT : Cet article est issu du système de traduction automatique mis au point par Microsoft (http://support.microsoft.com/gp/mtdetails). Un certain nombre d?articles obtenus par traduction automatique sont en effet mis à votre disposition en complément des articles traduits en langue française par des traducteurs professionnels. Cela vous permet d?avoir accès, dans votre propre langue, à l?ensemble des articles de la base de connaissances rédigés originellement en langue anglaise. Les articles traduits automatiquement ne sont pas toujours parfaits et peuvent comporter des erreurs de vocabulaire, de syntaxe ou de grammaire (probablement semblables aux erreurs que ferait une personne étrangère s?exprimant dans votre langue !). Néanmoins, mis à part ces imperfections, ces articles devraient suffire à vous orienter et à vous aider à résoudre votre problème. Microsoft s?efforce aussi continuellement de faire évoluer son système de traduction automatique.
La version anglaise de cet article est la suivante: 924954
L'INFORMATION CONTENUE DANS CE DOCUMENT EST FOURNIE PAR MICROSOFT SANS GARANTIE D'AUCUNE SORTE, EXPLICITE OU IMPLICITE. L'UTILISATEUR ASSUME LE RISQUE DE L'UTILISATION DU CONTENU DE CE DOCUMENT. CE DOCUMENT NE PEUT ETRE REVENDU OU CEDE EN ECHANGE D'UN QUELCONQUE PROFIT.

Envoyer des commentaires

 

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