CORRECTIF : Le fournisseur SQLOLEDB incorrectement laisse transaction ouverte

Traductions disponibles Traductions disponibles
Numéro d'article: 281633 - Voir les produits auxquels s'applique cet article
Cet article a été archivé. Il est proposé « en l'état » et ne sera plus mis à jour.
BOGUE : 58292 (SQLBUG_70)
BOGUE : 235846 (SHILOH)
Agrandir tout | Réduire tout

Sommaire

Symptômes

Exécute une certaine séquence de commandes impliquant des transactions explicites et des paramètres dans un programme d'application en utilisant le fournisseur SQLOLEDB incorrectement laisse une transaction non validée est ouverte. Cela peut entraîner de graves de blocage et d'autres problèmes.

Cause

Bien que l'option SET «implicit_transactions» est définie à OFF, le fournisseur SQLOLEDB ouverture d'une transaction implicite.

Résolution

MDAC 2.6

Pour résoudre ce problème, procurez-vous le dernier service pack Microsoft Data Access Components 2.6. Pour plus d'informations, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la base de connaissances Microsoft :
300635Comment faire pour obtenir la dernière pack de service MDAC 2.6

Correctif

IMPORTANT: (Microsoft Data Access Components) version 2.6 doit être installé avant d'appliquer ce correctif.

La version anglaise de ce correctif doit avoir les attributs de fichier suivants ou ceux d'une version ultérieure :
   Date       Time     Version     Size      File name      Platform
   -----------------------------------------------------------------
   11/22/00   8:43pm   8.00.0225   491,584   Sqloledb.dll   Intel
   11/22/00   8:43pm   8.00.0225    61,440   Sqloledb.rll   Intel
				
Remarque : dû dépendances de fichiers, la fonctionnalité qui contient les fichiers ci-dessus ou correctif plus récent peut également contenir des fichiers supplémentaires.

Contournement

Pour contourner ce problème, effectuez l'une des opérations suivantes :
  • Utilisez le fournisseur OLEDB pour ODBC plutôt que le SQLOLEDB fournisseur.

    - ou -
  • Placez des transactions supplémentaires autour du code qui crée le problème.

Statut

Microsoft a confirmé l'existence de ce problème dans le fournisseur OLE DB pour SQL Server qui est inclus dans les versions de Microsoft Data Access Components (MDAC) 2.1, 2.5 et 2.6.

MDAC 2.6

Ce problème a été corrigé dans Microsoft Data Access Components 2.6 Service Pack 1.


MDAC 2.5

Ce problème a été corrigé dans la version de Sqlredis.exe fournie avec Microsoft SQL Server 7.0 Service Pack 4.

Plus d'informations

Par le biais de l'application de suivi, vous pouvez le voir dans le Générateur de profils SQL Server que le fournisseur SQLOLEDB envoie les instructions suivantes à SQL Server :
SET FMTONLY ON select ... SET FMTONLY OFF
set implicit_transactions off SET NO_BROWSETABLE OFF
				
ce causes ' implicit_transaction ' qui est déjà ouvert.

Lorsque vous utilisez le fournisseur OLEDB pour ODBC et le pilote SQL Server au lieu de cela, le même code de Visual Basic/ADO exact envoie les instructions suivantes à SQL Server :
set implicit_transactions off SET NO_BROWSETABLE OFF
SET FMTONLY ON select  ... SET FMTONLY OFF
				
ainsi le FMTONLY SELECT s'ouvre une transaction implicite avec SQLOLEDB. Toutefois, parce que l'application ouverte jamais cette transaction, l'application sera normalement jamais fermer. Cette transaction est fermée uniquement lors de la prochaine transaction explicite.

Propriétés

Numéro d'article: 281633 - Dernière mise à jour: lundi 24 février 2014 - Version: 6.4
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft SQL Server 7.0 Standard
  • Microsoft SQL Server 2000 Standard
  • Microsoft Data Access Components 2.1
  • Microsoft Data Access Components 2.5
  • Microsoft Data Access Components 2.6
Mots-clés : 
kbnosurvey kbarchive kbmt kbhotfixserver kbqfe kbbug kbfix kbmdac260sp1fix kbqfe KB281633 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: 281633
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.

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