Fournisseur MSDASQL handles incorrectement SQL_NUMERIC_STRUCT Negatively Scaled valeurs

Traductions disponibles Traductions disponibles
Numéro d'article: 274604 - 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.
Agrandir tout | Réduire tout

Symptômes

Lorsque vous lisez des valeurs numériques à l'échelle négative à partir d'un pilote ODBC à l'aide du fournisseur OLE DB pour ODBC (MSDASQL) avec l'énumération de curseur adUseClient ActiveX Data Objects (ADO), les valeurs renvoyées sont tronquées.

Résolution

Pour résoudre ce problème, procurez-vous le dernier service pack pour Microsoft MDAC 2.5. Pour plus d'informations, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la base de connaissances Microsoft :
293312Procédure d'information : Pour obtenir le dernier MDAC 2.5 Service Pack
La version anglaise de ce correctif dispose des attributs de fichier (ou version ultérieure) répertoriés dans le tableau suivant. La date et l'heure de création de ces fichiers est exprimées en temps universel coordonné (UTC). Lorsque vous affichez les informations de fichier, il est converti en heure locale. Pour connaître le décalage entre l'heure UTC et l'heure locale, utilisez l'onglet fuseau horaire dans l'outil date et heure du Panneau de configuration.
   Date         Time   Version      Size     File Name
   --------------------------------------------------------------------
   31-Jan-2001  18:20  2.53.6131.0  303,376  Msdasql.dll
   31-Jan-2001  18:18  2.53.6131.0   16,384  Msdasqlr.dll
   31-Jan-2001  18:20  2.53.6131.0   78,096  Msdatl2.dll
   31-Jan-2001  18:20  2.53.6131.0   53,520  Msdatt.dll
   28-Feb-2001  18:00  1.10.101.0   484,408  Q277033_w2k_sp3_x86_en.exe
				

Contournement

Pour contourner ce problème, utilisez l'énumération adUseServer pour la propriété ADO CursorLocation au lieu de adUseClient.

Statut

Microsoft a confirmé l'existence de ce problème dans les produits Microsoft répertoriés au début de cet article. Ce problème a été corrigé dans Microsoft MDAC 2.5 Service Pack 3.

Plus d'informations

Si vous ouvrez un objet ADO Recordset par rapport à un pilote ODBC, le fournisseur OLE DB pour ODBC (MSDASQL) sert à fournir ODBC à des services de traduction de OLE DB. Si le jeu de résultats est demandé contient un champ numérique et si vous utilisez l'énumération adUseClient de la propriété CursorLocation, ADO tente d'extraire la valeur de champ numérique dans une structure OLEDB DB_NUMERIC.

Si le pilote ODBC sous-jacent signale qu'il est conforme à ODBC 3.0, MSDASQL essaie de se lier à des valeurs de SQL_NUMERIC_STRUCT directement au lieu de liaison à une chaîne de caractères. Si le SQL_NUMERIC_STRUCT le pilote renvoie possède une échelle négative et si le client du fournisseur MSDASQL demande une valeur DB_NUMERIC, MSDASQL convertit d'abord le SQL_NUMERIC_STRUCT dans une valeur DB_VARNUMERIC et puis convertit une valeur DB_NUMERIC. La conversion finale à une valeur DB_NUMERIC est traitée incorrectement si l'échelle est négatif, qui se traduit par une valeur tronquée.

Propriétés

Numéro d'article: 274604 - Dernière mise à jour: lundi 24 février 2014 - Version: 3.1
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft Data Access Components 1.5
  • Microsoft Data Access Components 2.0
  • Microsoft Data Access Components 2.1
  • Microsoft Data Access Components 2.1 Service Pack 2
  • Microsoft Data Access Components 2.5
Mots-clés : 
kbnosurvey kbarchive kbmt kbhotfixserver kbqfe kbmdac250sp3fix kbbug kbfix KB274604 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: 274604
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