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 :

Detecter un problème d'index / Paradox / BDE


Sujet :

Bases de données Delphi

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    183
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 183
    Points : 62
    Points
    62
    Par défaut Detecter un problème d'index / Paradox / BDE
    Bonjour à tous,

    J'utilise (D6 / BDE / Paradox) les compos TTable et TDataSource, j'utilise aussi l'utilitaire "VRepaire" pour réparer les index en cas des problèmes avec.

    Je cherche à savoir si il y a un moyen de détecter la défiance d'une table ou ces index.


    Merci à tous

  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
    Tant que tu n'as pas l'exception EBDEerror "Index is out of date", difficile de le savoir !

    C'est bien le problème de Paradox, c'est sa faible stabilité sous Windows !
    Windows lorsqu'il plante, le pire c'était sous Win2K avec le reboot sur défaillance irrémédiable (l'écran bleu)
    Cela n'avait pas le temps de finir les flush sur la table Paradox
    N'ayant pas utilisé Paradox à titre professionnel depuis Win2K, j'ignore son comportement sur les OS récents !


    Si tu en as les moyens, héberger tes fichiers Paradox sur un serveur UNIX accédé en Samba,
    une application multi-utilisateur sera nettement amélioré en terme de performance et de stabilité !

    Une approche simple serait aussi de réduire le plus que possible le temps d'ouverture des tables (ne pas faire un Open au lancement et le Close en fin de programme)
    Déjà même dans une fenêtre, le temps de saisie peut être long, utiliser un TClientDataSet comme tampon (en D6, il y avait déjà la TBDEClientDataSet) pour éviter un temps trop long entre un Open\Close
    D'ailleurs des Open\Close trop long nuise aussi à une utilisation concurrentielle !

    Utilisation du BDE pour placer en mémoire cache les mises à jour
    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 habitué
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2012
    Messages
    111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2012
    Messages : 111
    Points : 171
    Points
    171
    Par défaut
    bon jour
    dans paradox s'il on a un probleme d'ouverture de table c'est surement un probleme d'index il faux le supprimer et le recreé

    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
    try
            form1.table1.Open;
    except
         // supression des fichier index   (dans ce cas on un 1 index primaire et deux secondaire
         deletefile(pchar(DBPath + '\table1.PX'));
         deletefile(pchar(DBPath + '\table1.XG0'));
         deletefile(pchar(DBPath + '\table1.YG0'));
         deletefile(pchar(DBPath + '\table1.XG1'));
         deletefile(pchar(DBPath + '\table1.YG1'));
     
       // re creation des index 
                     with form1.table1 do
                    begin
                      AddIndex('','inxpim',[ixPrimary]); //création d'ndex primaire 
                       AddIndex('ind_sec1','champ1',[ixcaseinsensitive]);//création d'index secondaire nommé "ind_sec1" pour champ  "champ1"                
                      AddIndex('ind_sec2','date',[ixcaseinsensitive]);
                    end;                   
     
    form1.table1.open
    end;
    A+

Discussions similaires

  1. problème de MAJ d'un champs indexé / Paradox
    Par fveto dans le forum Bases de données
    Réponses: 2
    Dernier message: 06/03/2014, 18h33
  2. [BDD] Probléme avec fichir Paradox
    Par jcharles dans le forum Bases de données
    Réponses: 3
    Dernier message: 31/10/2004, 20h47
  3. Problème de mémoire avec BDE
    Par Machuet dans le forum Bases de données
    Réponses: 3
    Dernier message: 13/07/2004, 10h11
  4. Problémes mémoire avec le bde sur des bases paradox
    Par Keke des Iles dans le forum Bases de données
    Réponses: 2
    Dernier message: 27/05/2004, 16h55
  5. Problème d'index
    Par claude dans le forum SQL
    Réponses: 6
    Dernier message: 04/08/2003, 15h55

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