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 :

Fermeture de base de données INTERBASE6 SOUS DELPHI7 trop longue


Sujet :

Bases de données Delphi

  1. #1
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Février 2011
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations forums :
    Inscription : Février 2011
    Messages : 24
    Points : 24
    Points
    24
    Par défaut Fermeture de base de données INTERBASE6 SOUS DELPHI7 trop longue
    Salut,

    J'utilise un composant TIBDatabase, un composant TIBTransaction et plusieurs composants TIBDATASET pour accéder à la base de données sur un serveur dans un réseau local.

    Pour fermer la base de données et quitter le programme delphi je fait :
    1) TIBTransaction.Commit.
    2) .Close pour chaque TIBDATASET.
    3) TIBDatabase.Close.
    4) Application.Terminate.

    Ces dernières opérations me semble trop longue (+ de 10 secondes).


    Ma question : Que dois-je faire (ou pas faire) lors de la fermeture de base ?

    Si vous pouvez m'aider, Merci d'avance.

  2. #2
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 459
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    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 459
    Points : 24 873
    Points
    24 873
    Par défaut
    Normalement, tu ne devrais pas avoir besoin de faire ces COMMIT !
    Ils sont censés être fait !
    Une transaction reste une opération de courte durée garantissant la cohérence d'une modification des données !
    Une Transacation doit se limiter à une petite série de requête, souvent une action utilisateur, un clic sur un bouton qui déclenche l'insertion ou la modification des quelques enregistrements répartis sur quelques tables ne devant se produire qu'ensemble ou jamais !

    Ouvrir des TIBDataSet n'est pas non plus une bonne idée, tu peux te le permettre si des petites tables (1 à 1000 enreg) qui servent pour la configuration et traitement interne de l'application, surtout si utiliser en lecture.
    Pour les Tables métiers, utilise des TIBQuery !
    Evite les listings de milliers d'enregistrement, c'est souvent inutile, cela consomme de la mémoire !

    TIBDatabase.Close, très bien

    Application.Terminate, tu forces la fermeture ?
    C'est une fermeture non souhaité par l'utilisateur, un Close sur la MainForm arrête le programme proprement !
    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

Discussions similaires

  1. Réponses: 7
    Dernier message: 01/11/2013, 11h31
  2. Réponses: 1
    Dernier message: 04/04/2007, 08h44
  3. Création base de données Oracle sous Winwows
    Par madina dans le forum Oracle
    Réponses: 2
    Dernier message: 19/05/2006, 09h13
  4. Base de données embarquée sous Windows
    Par bouiboui dans le forum Décisions SGBD
    Réponses: 1
    Dernier message: 12/08/2004, 10h38

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