Lorsque vous utilisez un descripteur de fichier pour l'accès FileStream dans une transaction de SQL Server 2008, la transaction peut échouer aléatoirement valider dans Windows Server 2003 ou Windows XP Professionnel Édition x 64 Edition

Traductions disponibles Traductions disponibles
Numéro d'article: 955280 - Voir les produits auxquels s'applique cet article
Agrandir tout | Réduire tout

Sommaire

Symptômes

Sur un ordinateur qui exécute Windows Server 2003 ou Windows XP Professionnel Édition x 64, lorsque vous utilisez l'API OpenSqlFilestream ou la classe .NET SqlFilestream pour obtenir un descripteur de fichier pour l'accès FileStream dans une transaction dans Microsoft SQL Server 2008, la transaction peut ne pas aléatoire valider. Lorsque ce problème se produit, une des erreurs suivantes est enregistrée dans le fichier de SQL Server Errorlog :
  • 3910 (Contexte de transaction utilisé par une autre session)
  • 3981 (L'opération de transaction ne peut pas être effectuée car il existe en attente de demandes de travailler sur cette transaction)
  • 3922 (Ne peut pas inscrire dans la transaction car la transaction n'existe pas)
La cause de ce problème n'est pas liée à la fonctionnalité FILESTREAM dans SQL Server 2008. Toutefois, vous généralement rencontrer ce problème lorsque vous utilisez la fonctionnalité FILESTREAM dans SQL Server 2008.

Cause

Ce problème se produit en raison d'une erreur dans le service serveur. Le service serveur incorrecte retards fermer le fichier gérer. Par conséquent, SQL Server 2008 Impossible d'effectuer les opérations de validation.

Résolution

Informations sur le correctif

Windows Server 2003

Un correctif est désormais disponible auprès de Microsoft. Toutefois, il est conçu uniquement pour corriger le problème décrit dans cet article. S'il s'appliquent 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.

Pour résoudre ce problème immédiatement, contactez services de support technique Microsoft afin d'obtenir le correctif logiciel. Pour une liste complète des numéros de téléphone services de support technique Microsoft et des informations sur les frais engendrés, reportez-vous au site de Web Microsoft suivant :
http://support.microsoft.com/contactus/?ws=support
note Dans certains cas, les frais aucuns de support peuvent être facturés si un technicien du support technique Microsoft détermine qu'une mise à jour spécifique peut résoudre votre problème. Les coûts habituels du support technique s'appliqueront aux autres questions et problèmes non traités par la mise à jour en question.
Conditions préalables
Pour appliquer ce correctif, vous devez exécuter Windows Server 2003 Service Pack 1, Windows Server 2003 Service Pack 2, Windows XP Professionnel Édition x 64 ou Windows XP Professionnel Édition x 64 Edition Service Pack 2 sur l'ordinateur.
Demande de redémarrage
Vous devez redémarrer l'ordinateur après avoir appliqué ce correctif.
Informations sur le remplacement de correctif
Ce correctif ne remplace pas un correctif précédemment publiée.
Informations de fichier
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.

Windows Server 2003 avec Service Pack 1, x 86 versions
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
SRV.sys5.2.3790.3177361,47218-Juillet 200810:15x 86

Windows Server 2003 avec Service Pack 1 , x 64-versions
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
SRV.sys5.2.3790.3177674,81621-Juillet 200807:32x 64
Windows Server 2003 Service Pack 1, versions Itanium
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
SRV.sys5.2.3790.31771,110,52821-Juillet 200807:32IA-64

Windows Server 2003 avec Service Pack 2, x 86 versions
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
SRV.sys5.2.3790.4337358,40018-Juillet 200812:04x 86

Windows Server 2003 avec Service Pack 2, versions 64 x
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
SRV.sys5.2.3790.4337648,19221-Juillet 200814:57x 64

Windows Server 2003 avec Service Pack 2, versions Itanium
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
SRV.sys5.2.3790.43371,111,55221-Juillet 200814:54IA-64

Windows XP Professionnel Édition x 64

Un correctif est désormais disponible auprès de Microsoft. Toutefois, il est conçu uniquement pour corriger le problème décrit dans cet article. S'il s'appliquent 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.

Pour résoudre ce problème immédiatement, contactez services de support technique Microsoft afin d'obtenir le correctif logiciel. Pour une liste complète des numéros de téléphone services de support technique Microsoft et des informations sur les frais engendrés, reportez-vous au site de Web Microsoft suivant :
http://support.microsoft.com/contactus/?ws=support
note Dans certains cas, les frais aucuns de support peuvent être facturés si un technicien du support technique Microsoft détermine qu'une mise à jour spécifique peut résoudre votre problème. Les coûts habituels du support technique s'appliqueront aux autres questions et problèmes non traités par la mise à jour en question.
Conditions préalables
Pour appliquer ce correctif, vous devez exécuter Windows XP Professionnel Édition x 64 ou Windows XP Professionnel Édition x 64 Edition Service Pack 2 sur l'ordinateur.
Demande de redémarrage
Vous devez redémarrer l'ordinateur après avoir appliqué ce correctif.
Informations sur le remplacement de correctif
Ce correctif ne remplace pas un correctif précédemment publiée.
Informations de fichier
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.

Windows XP Professionnel Édition x 64
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
SRV.sys5.2.3790.3177674,81621-Juillet 200807:32x 64

Windows XP Professionnel Édition x 64 avec Service Pack 2
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
SRV.sys5.2.3790.4337648,19221-Juillet 200814:57x 64

Contournement

important Cette section, la méthode ou la tâche, contient des étapes qui vous indiquent comment modifier le Registre. Toutefois, des problèmes graves peuvent se produire si modification incorrecte du Registre. Par conséquent, assurez-vous que ces étapes avec soin. Pour la protection supplémentaire, sauvegarder le Registre avant de le modifier. Ensuite, vous pouvez restaurer le Registre si un problème se produit. Pour plus d'informations sur la façon sauvegarder et restaurer le Registre, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
322756 Comment faire pour sauvegarder et restaurer le Registre dans Windows
Avertissement Cette solution de contournement provoque un problème de performances lorsque vous fonctionne sur fichiers partagez dans le système.


Pour contourner ce problème, définissez la valeur de l'entrée de Registre Cachedopenlimit sur 0 , puis redémarrez le service serveur. Pour ce faire, procédez comme suit :
  1. Dans l'Éditeur du Registre, recherchez la sous-clé de Registre suivante :
    HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Lanmanserver\Parameters
  2. Sous la sous-clé de Registre paramètres , cliquez sur Modifier , cliquez sur Nouveau , cliquez sur valeur DWORD , tapez Cachedopenlimit et puis appuyez sur ENTRÉE.
  3. Définissez la valeur décimale de l'entrée de Registre Cachedopenlimit à 0 .
  4. Redémarrez le service serveur.
note Par défaut, la valeur de l'entrée de Registre Cachedopenlimit est 5 , même si vous n'avez pas défini il.

Avertissement Lorsque vous définissez la valeur sur 0 , descripteurs de fichiers de tous les fichiers partagés ne sont pas mis en cache par le système. Cela peut entraîner un problème de performances lorsque vous accédez à fichiers partagés dans le système.

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

Ce problème se produit également dans Windows Server 2008 et Windows XP x 86 versions. Pour plus d'informations sur ce problème dans Windows Server 2008, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
953263 Lorsque vous utilisez une instruction Transact-SQL pour fonctionner sur une colonne FILESTREAM dans SQL Server 2008, l'instruction peut échouer aléatoirement valider et entraîner la corruption des données dans Windows Server 2008
Pour plus d'informations sur ce problème dans Windows XP x 86 versions, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
955567 Une altération des données peut se produire lorsque vous essayez d'ajouter des données à une FILESTREAM varbinary (max.) colonne dans SQL Server 2008 sur un ordinateur Windows XP
Pour plus d'informations sur la terminologie mise à jour logicielles, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances:-
824684 Description de la terminologie standard utilisée pour décrire les mises à jour logicielles Microsoft

Quand utiliser le stockage FILESTREAM

Dans SQL Server 2008, les données de grand objet BLOB (binary) Object peuvent être les données du type de VARBINARY(MAX) qui stocke des données dans des tables de base de données. Données BLOB peuvent également être les les données de la type VARBINARY(MAX) FILESTREAM qui stocke les données dans le système de fichiers. La taille des données et l'utilisation de données déterminent si vous devez utiliser le stockage de base de données ou le stockage FILESTREAM . Vous devez envisager d'utiliser le stockage FILESTREAM lorsque les conditions suivantes sont remplies :
  • En moyenne, les données BLOB que vous stockez sont supérieure à 1 mégaoctet (Mo).
  • Accès en lecture rapide est important.
  • Vous développez des applications qui utilisent un niveau intermédiaire pour la logique d'application.
Si les données BLOB sont inférieure à 1 Mo, vous devez envisager d'utiliser le stockage de base de données. Le stockage de base de données fournit souvent performances mieux en continu.

Pour plus d'informations, reportez-vous au site de Web MSDN (Microsoft Developer Network) suivant :
http://msdn.microsoft.com/en-us/library/bb933993.aspx

Propriétés

Numéro d'article: 955280 - Dernière mise à jour: mardi 13 janvier 2009 - Version: 2.0
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft Windows Server 2003, Web Edition
  • Microsoft Windows Server 2003, Datacenter Edition (32-bit x86)
  • Microsoft Windows Server 2003, Datacenter Edition for Itanium-Based Systems
  • Microsoft Windows Server 2003, Datacenter x64 Edition
  • Microsoft Windows Server 2003, Enterprise x64 Edition
  • Microsoft Windows Server 2003, Enterprise Edition (32-bit x86)
  • Microsoft Windows Server 2003, Enterprise Edition for Itanium-based Systems
  • Microsoft Windows Server 2003, Standard x64 Edition
  • Microsoft Windows Server 2003, Standard Edition (32-bit x86)
  • Microsoft Windows XP Professional x64 Edition
Mots-clés : 
kbmt kbexpertiseadvanced kbfix kbautohotfix kbsurveynew kbqfe kbhotfixserver KB955280 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: 955280
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