CORRECTIF : sans enregistrements peuvent être renvoyées lorsque vous appelez la fonction SQLExecute pour exécuter une instruction préparée et que vous utilisez le pilote ODBC SQL native client dans SQL Server 2008

Traductions disponibles Traductions disponibles
Numéro d'article: 957387 - Voir les produits auxquels s'applique cet article
Bogue #: 50003391 (correctifs SQL)
Agrandir tout | Réduire tout

Sommaire

Symptômes

Vous utilisez le pilote ODBC SQL native client dans Microsoft SQL Server 2008. Si vous appelez la fonction SQLExecute pour exécuter une instruction préparée, aucun enregistrement ne peut être renvoyée. Toutefois, si vous utilisez le pilote ODBC SQL native client dans SQL Server 2005 pour appeler la fonction SQLExecute , enregistrements sont renvoyés.

Cause

Ce problème peut se produire en raison d'un bogue dans le pilote ODBC client natif de SQL dans SQL Server 2008. Il peut se produire si vous appelez la fonction SQLBindParameter avant chaque fonction SQLExecute . Consultez la section « Plus informations » pour plus d'informations.

Résolution

Informations de mise à jour cumulative

Le correctif de ce problème a été tout d'abord publié en mise à jour cumulatif 1. Pour plus d'informations sur la façon d'obtenir ce package de mise à jour cumulative pour SQL Server 2008, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
956717 Package de cumulative mise à jour 1 pour SQL Server 2008
note Les versions étant cumulatifs, chaque nouvelle version de correctif contient tous les correctifs et tous les correctifs de sécurité qui étaient fournis avec la précédente SQL Server 2008 version du correctif. Microsoft recommande que vous considérez comme application de la version de correctif plus récente qui comprendra ce correctif. Pour plus d'informations, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
956909 SQL Server 2008 versions publiées après le lancement de SQL Server 2008

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.

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.
SQL Server 2008, éditions 32 bits
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Kfsqlncli.dll2007.100.1755.016,920Sep-06-200815:23x 86
Sqlncli10.dll2007.100.1755.02,459,672Sep-06-200815:40x 86
SQL Server 2008, éditions 64 bits
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Kfsqlncli.dll2007.100.1755.017,432Sep-06-200820:57x 64
Sqlncli10.dll2007.100.1755.03,158,552Sep-06-200821:12x 64

Contournement

Pour contourner ce problème, appelez la fonction SQLBindParameter une seule fois. Lorsque vous appelez la fonction SQLBindParameter , assurez-vous que les conditions suivantes sont remplies :
  • L'argument TailleColonne est de taille suffisante.
  • L'argument Strlen_or_IndPtr est défini sur SQL_NTS.
Une fois le premier appel de la fonction SQLExecute effectuée, la nouvelle valeur de chaîne peut être copiée dans l'argument ParameterValuePtr .

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 avec l'appel SQLBindParameter . Si la mémoire tampon précédent correspond à la taille de la longueur de valeur suivant, un re-prepare de l'instruction est émise pas. Dans l'exemple suivant d'une trace D'ODBC, tampon le paramètre initial correspond à la longueur du nouveau paramètre.

Paramètre initial :
ec8-b6c EXIT SQLBindParameter avec le code de retour 0 (SQL_SUCCESS)
HSTMT 05A8E260
UWORD 1
SWORD 1 <SQL_PARAM_INPUT>
SWORD-8 <SQL_C_WCHAR>
SWORD-9 <SQL_WVARCHAR>
SQLULEN 7
SWORD 0
POINTEUR 0X028C8A98
SQLLEN 65 535
SQLLEN * 0X050506F8 (14)
Suivant le nouveau paramètre :
ec8-b6c EXIT SQLBindParameter avec le code de retour 0 (SQL_SUCCESS)
HSTMT 05A8E260
UWORD 1
SWORD 1 <SQL_PARAM_INPUT>
SWORD-8 <SQL_C_WCHAR>
SWORD-9 <SQL_WVARCHAR>
SQLULEN 14
SWORD 0
POINTEUR 0X028C4F80
SQLLEN 65 535
SQLLEN * 0X050506F8 (28)

Références

Pour plus d'informations sur la fonction SQLExecute , reportez-vous au site de Web MSDN (Microsoft Developer Network) suivant :
http://msdn.microsoft.com/en-us/library/ms713584(VS.85).aspx
Pour plus d'informations sur la fonction SQLBindParameter , reportez-vous au site Web MSDN suivant :
http://msdn.microsoft.com/en-us/library/ms710963(VS.85).aspx

Propriétés

Numéro d'article: 957387 - Dernière mise à jour: lundi 17 novembre 2008 - Version: 2.0
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Standard Edition for Small Business
Mots-clés : 
kbmt kbautohotfix kbexpertiseinter kbfix kbbug kbqfe kbhotfixserver KB957387 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: 957387
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