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

Bases de données Delphi Discussion :

Copier un index multiple [Delphi7] [DBase]


Sujet :

Bases de données Delphi

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    176
    Détails du profil
    Informations personnelles :
    Âge : 74
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 176
    Points : 123
    Points
    123
    Par défaut Copier un index multiple [Delphi7] [DBase]
    Bonjour et meilleurs voeux à toutes et à tous.

    Clipper 5 (sous DOS) proposait l'instruction bien pratique Copy Stru pour copier une base et ses index. Je viens de faire l'équivalent sous Delphi : ça marche pour les index simples, mais ça plante pour les index multiples.

    Exemple de création d'un index multiple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
            with AddIndexDef do
               begin
                  Name := 'IDX_MULT';
                  Fields := 'Nom+Prenom';
                  Options :=[ixExpression];
               end;
    Lors de la copie, je parviens à récupérer Name := 'IDX_MULT' et Options := [ixExpression], mais pas Fields qui semble vide, d'où plantage.

    Si quelqu'un a une idée... D'avance merci.

    Cordialement,

    Alain
    Ce qui est simple et évident pour soi-même ne l'est pas forcément pour les autres... et réciproquement !

  2. #2
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 447
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    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 : 13 447
    Points : 24 849
    Points
    24 849
    Par défaut
    Utilise les Composants Apollo de Vista Sofware, il gère les index multiples ainsi que les NDX et SDX

    si tu veux récupérer le contenu de l'index via le BDE, tu dois écrire ton expression dans Fields effectivement, par contre ensuite, il faut consulter Expression
    Faudrait lire l'aide c'est écrit dedans !

    Citation Envoyé par Aide de Delphi 7
    Remarque : Lors de la création d'index d'expressions dBASE, n'utilisez pas de liste de champs séparés par des points-virgules. Initialisez Fields à une expression du langage de manipulation de données dBASE concaténant plusieurs champs, convertissant des types de données de champs ou utilisant des sous-chaînes de champs. Vous devez inclure la valeur TIndexOption ixExpression dans le paramètre Options des fonctions telles que TIndexDefs.Add ou dans la propriété Options d'un objet TIndexDef. Lors de l'examen d'index d'expressions dBASE existants, utilisez la propriété Expression à la place de la propriété Fields.
    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 régulier
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    176
    Détails du profil
    Informations personnelles :
    Âge : 74
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 176
    Points : 123
    Points
    123
    Par défaut
    Merci ShaiLeTroll.
    Je vais essayer d'exploiter ta piste.
    Ce qui est simple et évident pour soi-même ne l'est pas forcément pour les autres... et réciproquement !

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    176
    Détails du profil
    Informations personnelles :
    Âge : 74
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 176
    Points : 123
    Points
    123
    Par défaut
    Bonjour,

    Voici le résultat de l'exploitation de la piste fournie par ShaiLeTroll :

    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
     
      with AddIndexDef do
        // Pour un index simple...
        begin
          Name := 'IDX_SIMPLE';           // nom de l'index simple
          Fields := 'Nom';                // indexation sur le champ Nom
          Options :=[];                   // éventuellement, Options : [ix Primary], etc...
        end;
        // Pour un index multiple...
        begin
          Chaine := 'Nom'+'+'+'Prenom';  // concaténation : résultat = 'Nom+Prenom'
          Name := 'IDX_MULT';            // nom de l'index multiple
          Expression := Chaine;          // indexation sur les champs Nom et Prenom
          Options :=[ixExpression];      // Options : obligatoire = [ixExpression]
        end;
    Merci encore.

    Cordialement,
    Alain

    PS : je cherche régulièrement dans l'Aide de Delphi, mais ce n'est pas toujours évident de s'y retrouver (ceci en réponse amicale à : "Faudrait lire l'aide c'est écrit dedans !")
    Ce qui est simple et évident pour soi-même ne l'est pas forcément pour les autres... et réciproquement !

  5. #5
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 447
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    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 : 13 447
    Points : 24 849
    Points
    24 849
    Par défaut
    Ne t'inquiète pas, je le balance tout le temps, ... parce que je connaissais pas moi même la réponse, et je l'ai trouvé dans l'aide (j'utilise ApolloTable qui gère parfaitement DBASE avec des méthodes dédiées, je ne l'utilise pas par le BDE) ... surtout que celle de D7 est une vrai merveille comparée aux versions suivantes ... quoi que Delphi 2009 redresse la barre (même si très lourde en mémoire)

    Sinon, merci d'avoir fourni ton code, cela pourra servir à d'autres !
    Si ils pensent à utiliser la fonction rechercher du forum
    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

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Delphi 7] [DBase 4] Index multiple
    Par alainvh dans le forum Bases de données
    Réponses: 22
    Dernier message: 04/11/2016, 15h19
  2. [Lazarus] Création d'index multiples tables de type dBase
    Par ovni76 dans le forum Lazarus
    Réponses: 7
    Dernier message: 13/04/2009, 14h33
  3. Conseil pour Indexer une table DBase
    Par alainvh dans le forum Bases de données
    Réponses: 4
    Dernier message: 08/05/2006, 22h27
  4. Dbase et index multiples
    Par jeff&Natacha dans le forum Autres SGBD
    Réponses: 1
    Dernier message: 29/04/2005, 10h47
  5. index multiple
    Par mona dans le forum Débuter
    Réponses: 5
    Dernier message: 26/04/2005, 19h45

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