IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C++Builder Discussion :

Specifier le chemin de BDD dBASE sans passer par odbc


Sujet :

C++Builder

  1. #1
    Membre éclairé
    Inscrit en
    Avril 2008
    Messages
    335
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 335
    Par défaut Specifier le chemin de BDD dBASE sans passer par odbc
    Bonjour

    pour déclarer la source de donnée dans l'ODBC pas de problème. mais
    quand je vérifie dans odbc de windows, je trouve l'alias créer mais le chemin de répertoire n'est pas spécifié.voici le code que j'ai utilisée:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    bool CreateAliasODBC( AnsiString aAliasName, AnsiString aFilenameMDB )
    {
      TRegistry *reg = new TRegistry() ;
      reg->RootKey = HKEY_CURRENT_USER ;
     
      if( !reg->OpenKey( "\\Software\\ODBC\\ODBC.INI\\ODBC Data Sources",false ) )
      {
     
         return( false ) ;
     
      }
      reg->WriteString( aAliasName, "Microsoft Access dBASE Driver (*.dbf, *.ndx, *.mdx)" ) ;
     
      if( !reg->OpenKey("\\Software\\ODBC\\ODBC.INI\\" +aAliasName,true) )
      {
     
        return( false );
     
      }
      reg->WriteString( "DefaultDir", aFilenameMDB ) ;
      reg->WriteString( "Driver", "C:\\PROGRA~1\\FICHIE~1\\MICROS~1\\OFFICE12\\ACEODBC.DLL" ) ;
      reg->WriteInteger( "DriverId", 25 ) ;
      reg->WriteString( "FIL", "dBASE 5.0" ) ;
      reg->WriteString( "UID", "" ) ;
      reg->WriteInteger( "SafeTransactions", 0 ) ;
      delete reg ;
      return( true );
    }
    ////////////
    CreateAliasODBC( "alias",Chemin) ;
    merci d'avance pour votre aide

  2. #2
    Expert éminent
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 076
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 14 076
    Par défaut
    Quel Provider\Driver ? Quelle Lib ?
    BDE (utilise l'objet Session pour ajouter des Alias)
    ADO (reste avec ODBC mais évite la Base de Registre, il doit exister des API propres pour le faire)
    Apollo (configuration manuelle dans les TApolloTable)
    ?
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  3. #3
    Membre éclairé
    Inscrit en
    Avril 2008
    Messages
    335
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 335
    Par défaut
    Bonjour,
    merci ShaileTroll pour votre réponse.
    j'utilise base de données dBase File (*.dbf) avec un programme réalisé sous c++ builder v6 et j'utilse BDE, pour déclarer la source de donnée dans l'ODBC j'ai suivi la procédure de crée une clé dans la base des registres. le problème que j'ai dans le code précédent le chemin de répertoire de fichier de base de données (*.dbf) n'est pas spécifié.
    merci d'avance

  4. #4
    Expert éminent
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 076
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 14 076
    Par défaut
    Tu utilises le BDE ?
    Utilise donc les Alias du BDE ! c'est fait pour cela, regarde l'Objet TSession
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  5. #5
    Membre éclairé
    Inscrit en
    Avril 2008
    Messages
    335
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 335
    Par défaut
    salut,
    oui j'utilise BDE,
    j'ai pas un problème dans le cas ou je crée l'alias ODBC de façon "classique" manuellement. mais ce que je veut de déclarer l'alias dans le code de l'application, la source de donnée et de permettre de changer le fichier de Base de Données (*.dbf) dans le logiciel sans passé par ODBC de windows.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CreateAliasODBC( "NOM_ALIAS", "C:\\BDD\\FICHIER.dbf" )
    pourtant quand j'utilise ce code avec access il fonctionne parfaitement.
    fenêtre d'erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Erreur SQ générale
    [pilote odbc dBASE Inconnu] n'est pas un chemin d'accés valide
    merci d'avance

  6. #6
    Expert éminent
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 076
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 14 076
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    reg->WriteString( "Driver", "C:\\PROGRA~1\\FICHIE~1\\MICROS~1\\OFFICE12\\ACEODBC.DLL" ) ;
      reg->WriteInteger( "DriverId", 25 ) ;
    tu ne trouve pas que ça c'est spécifique à ACCESS !
    Tu ne comprends pas le code que tu utilises ! Faut réfléchir un peu !
    Il faut fournir le Bon Driver !


    Après, je ne vois pas pourquoi, tu passes par ODBC pour tes Alias BDE,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Session.AddStandardAlias("NOM_ALIAS", "C:\\BDD\\FICHIER.dbf", "DBASE");
    Alias que tu peux directement dans TDataBase.DatabaseName
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  7. #7
    Membre éclairé
    Inscrit en
    Avril 2008
    Messages
    335
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 335
    Par défaut
    Bonjour,
    oui j'ai changée le driver pour access j'ai utilisée
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    reg->WriteString( "Driver", "C:\\WINDOWS\\System32\\odbcjt32.dll" ) ;
      reg->WriteInteger( "DriverId", 25 ) ;
    pour dBASE
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    reg->WriteString( "Driver", "C:\\PROGRA~1\\FICHIE~1\\MICROS~1\\OFFICE12\\ACEODBC.DLL" ) ;
      reg->WriteInteger( "DriverId", 533 ) ;
    je vais essayer votre méthode de créer alias sans passer par ODBC.

Discussions similaires

  1. [BDE][Access] utilisation de BDDs sans passer par ODBC
    Par Guigui_ dans le forum Bases de données
    Réponses: 4
    Dernier message: 23/01/2005, 14h11
  2. Réponses: 2
    Dernier message: 06/01/2005, 21h09
  3. Réponses: 4
    Dernier message: 05/02/2004, 18h18
  4. Afficher une image sans passer par les textures
    Par Black_Daimond dans le forum DirectX
    Réponses: 3
    Dernier message: 09/05/2003, 19h13
  5. [Kylix] Débrider Kylix sans passer par le Net
    Par BXDSPORT dans le forum EDI
    Réponses: 1
    Dernier message: 23/03/2003, 10h52

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo