CORRECTIF : pilote Microsoft ODBC pour Oracle n'est pas réussie de curseur client avec Embedded CROCHET

Traductions disponibles Traductions disponibles
Numéro d'article: 292604 - 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

Sommaire

Symptômes

Lorsque vous utilisez un curseur côté client contre un Oracle base de données avec le pilote Microsoft ODBC pour Oracle, une mise à jour différée pas réussi et vous recevez le message d'erreur suivantes :
0 x 80004005 (« insuffisant table de base informations pour mettre à jour ou actualisation »)
Ce problème se produit lorsque l'instruction SQL SELECT contient une clause WHERE ayant une fourchette incorporé. Le problème se produit uniquement avec un curseur côté client lorsque les critères dans la clause WHERE du jeu d'enregistrements est mises en parenthèses et le critère de chaîne contient des crochets.

Cause

Le moteur de curseur client (ActiveX Data Objects) ne pas analyser correctement l'instruction et ne peut pas mettre à jour le jeu d'enregistrements.

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 :
293312INFO : Comment faire 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. Les dates et heures de ces fichiers sont exprimées en coordinated universal temps (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'outil Date et heure du Panneau de configuration.
   Date         Version       Size     File name     Platform
   ----------------------------------------------------------------
   03-07-2001   2.53.7307     327,952  Msadce.dll    x86
				

Statut

Microsoft a confirmé que c'est un 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

Le problème ne se produit pas avec le Microsoft OLE DB fournisseur MSDAORA pour Oracle.

Procédure pour reproduire le comportement

  1. Créer un nouveau Microsoft Visual Basic 6.0 EXE standard Project. Par défaut, Form1 est créé.
  2. Dans le menu projet , cliquez sur Références et ajoutez ensuite une référence à Microsoft ActiveX Data Objects 2.5 Library.
  3. Collez le code suivant dans l'événement Form_Load de Form1 :
    
    
      Dim con As ADODB.Connection
      Dim rst As ADODB.Recordset
      
      Set con = New ADODB.Connection
      With con
        .CursorLocation = adUseClient
        .ConnectionString = "Provider=MSDASQL.1;UID=MyUser;PWD=MyPwd;DRIVER={Microsoft ODBC for Oracle};SERVER=MyServer;"
        .Open
      End With
      
      Set rst = New ADODB.Recordset
      With rst
        .ActiveConnection = con
        .CursorLocation = adUseClient
        .CursorType = adOpenStatic
        .LockType = adLockOptimistic
        'This one fails!
        .Source = "SELECT MyKey,UpdateVal,LookUpVal FROM UpdateTest WHERE (LookUpVal = 'Test2(Test2')"
        'This one works!
            '.Source = "SELECT MyKey,UpdateVal,LookUpVal FROM UpdateTest where LookUpVal='Test1'"
        .Open
      End With
      
      rst.Fields(1).Value = 200
      rst.Update
    					
  4. Modifier pour vous connecter à votre Oracle la chaîne de connexion serveur.
  5. Créer une table UpdateTest avec MyKey (clé primaire), UpdateVal et LookUpVal.
  6. Ajoutez deux lignes comme suit :
    • Premier enregistrement contient LookUpVal = Test2(Test2
    • Second enregistrement contient LookUpVal = Test1

  7. Démarrer le projet.

Propriétés

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