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 :

Vitesse d'exécution SIBProvider , Delphi 7, QuickReport4.04, Ado et Interbase 7.5


Sujet :

Bases de données Delphi

  1. #1
    Membre du Club
    Inscrit en
    Août 2002
    Messages
    65
    Détails du profil
    Informations forums :
    Inscription : Août 2002
    Messages : 65
    Points : 64
    Points
    64
    Par défaut Vitesse d'exécution SIBProvider , Delphi 7, QuickReport4.04, Ado et Interbase 7.5
    Bonjour,
    J'ai developpe une application de gestion avec Delphi 7. J'utilise les composants ADO étant donné que BDE n'est plus maintenu.
    Mon soucis c'est que je trouve que l'application est particulièrement lente qu'and il s'agit de prévisualiser les états.
    J'ai optimisé mes requètes en utilisant des paramètres et en ajoutant des indexes sur les tables afin de permettre au serveur de bien parser les requètes
    C'est pas ma machine qui n'est pas puissante car d'autres applis installées sur la même machine s'exécutent 1000 fois plus vite avec 1000 fois plus de données.
    Merci d'avance pour votre aide.
    Config : Win XP SP2, 4 Go RAM, Petium IV 3 (+)Ghz
    Les vrais informaticiens n'ont pas d'attaché-case ; leur tête suffit à transporter leurs connaissances.

  2. #2
    Expert éminent
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 903
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 903
    Points : 6 027
    Points
    6 027
    "Il n'y a pas de bonnes réponses à une mauvaise question." (M. Godet)
    -----------------------
    Pensez à cloturer votre sujet - Aucune réponse aux sollicitations techniques par MP
    Usus magister est optimus

  3. #3
    Membre du Club
    Inscrit en
    Août 2002
    Messages
    65
    Détails du profil
    Informations forums :
    Inscription : Août 2002
    Messages : 65
    Points : 64
    Points
    64
    Par défaut
    Oui, j'ai déjà lu ca. En fait j'utilise interbase 7.5 pas 6. C'est le problème de lenteur avec interbase 6 qui m'a fait migrer.
    Avec BDE, c'est très rapide(?)
    Les vrais informaticiens n'ont pas d'attaché-case ; leur tête suffit à transporter leurs connaissances.

  4. #4
    Expert confirmé

    Profil pro
    Leader Technique
    Inscrit en
    Juin 2005
    Messages
    1 756
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Leader Technique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2005
    Messages : 1 756
    Points : 4 170
    Points
    4 170
    Par défaut
    La première chose à faire c'est identifier la raison de cette lenteur.

    Pour celà, il faudrait profiler l'exécution de la prévisualition des Etats :
    - Visualiser précisément quelles sont les requêtes exécutées.
    - Identifier les temps d'exécutions : Temps d'exécution de chaque requête, durée écoulée entre chaque requête.
    - Si possible détailler les temps d'exécution d'une requête entre : temps d'exécution sur le SGBD et temps de lecture des résultats.
    Et si tu peux avoir le nombre de lignes retournées par chaque requête c'est encore mieux.

    De cette façon tu verras si :
    - Les temps d'exécution des requêtes sont courts, mais la durée entre deux requêtes est importante : Le problème ne vient pas de la base mais du générateur d'état.
    - Le temps d'exécution d'une requête en particulier est important : Il faut chercher à optimiser cette dernière.
    - Le temps d'exécution est rapide mais le temps de lecture du jeu de données est important : Le problème vient du réseau ou du l'API pour accéder à la base. Ou encore, elle retourne plus de données que nécessaire. Si c'est le réseau on n'y peut pas grand chose. Si c'est l'API, essayer d'en changer...
    - La génération de l'état passe par l'exécution de très nombreuses petites requêtes : Il faut voir comment diminuer le nombre de requête exécutée. Si c'est toi qui à la main sur ces requêtes, tu peux te débrouiller pour en faire moins. Si c'est le générateur d'état qui décide qu'elles requêtes il doit faire, tu es mal...

    Donc la question maintenant c'est comment profiler les requêtes qui s'exécutent ?
    Je ne sais pas si Interbase dispose d'un profiler, donc on va faire comme si ce n'était pas le cas.
    Je te conseille alors d'utiliser ETW pour instrumenter ton code et générer une trace temps réel des requêtes qui s'exécutent.
    Puisque tu utilises ADO, il te suffirait d'ajouter l'instrumentation dans les événements de la connexion ADO.

    J'ai écris un tuto sur le sujet (ETW, instrumentation des requêtes, ainsi que le profiler et la librairie prête à l'emploi). Tu as le lien dans ma signature.

Discussions similaires

  1. Réponses: 4
    Dernier message: 30/04/2009, 09h34
  2. Au sujet de la vitesse d'exécution des programmes
    Par emie31 dans le forum Langage
    Réponses: 5
    Dernier message: 09/11/2006, 13h42
  3. Impossible de compiler (exécuter) sous Delphi 7
    Par patrice@ dans le forum Delphi
    Réponses: 18
    Dernier message: 26/07/2006, 18h25
  4. Réponses: 4
    Dernier message: 02/04/2006, 18h42
  5. Erreurs d'exécution sous delphi 5
    Par nkd dans le forum Langage
    Réponses: 3
    Dernier message: 06/11/2004, 17h25

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