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 :

Les transactions avec Delphi & InterBase


Sujet :

Bases de données Delphi

  1. #1
    Membre à l'essai
    Inscrit en
    Mai 2004
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 13
    Points : 13
    Points
    13
    Par défaut Les transactions avec Delphi & InterBase
    salut,
    J'ai ma base de données en InterBase6 de 9 tables, et je developpe avec delphi .
    je veut que mon application tourne sur 6 posts,
    j'utilise les composants IBDataSet et IBQuery

    je cherche a comprendre les principe des transactions, estce que pour chaque IBDataSet je doit affecter une transation ou bien une seul transaction pour tt les tables .

    au stade du developpement j'avai pas problème (mon application tourne sur un seul poste), lorsque les autres postes accede à BD il y a un blocage.

    je pense que c'est a cause d'étuliser qu'une seul transaction pour tous les tables.

    dans l'attente de vous lire Salutations.
    A+

  2. #2
    Membre confirmé Avatar de JustMe
    Inscrit en
    Juillet 2002
    Messages
    479
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 479
    Points : 594
    Points
    594
    Par défaut
    Une transaction est une série d'opération au sein de l'SGBD qui soit réussissent toutes ou s'annullent toutes. c'est pour préserver la cohérence de la base de données.
    Une transaction est activé ensuite appliquée pour une série d'opérations sans a avoir à mettre en cause le ou les objets qui font la mise à jours.

  3. #3
    Membre à l'essai
    Inscrit en
    Mai 2004
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 13
    Points : 13
    Points
    13
    Par défaut
    ReSalut,
    Je parle de du composant IBTransaction et non de la transation au niveau du SGBD.

    A+

  4. #4
    Membre actif

    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    485
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 485
    Points : 269
    Points
    269
    Par défaut
    1 seul IBTransaction est nécessaire et suffisant pour tous les IBDataset sauf cas particulier.

    Les transactions garantissent l'intégrité de la BDD mais obligent à une certaine rigueur dans la mise à disposition des données. Si une transaction est commencée sur un poste, les autres postes ne peuvent plus accéder aux données en cours de modification tant que la transaction n'est pas terminée. Il faut donc toujours vérifier que l'on dispose de la main sur les données avant de proposer à l'utilisateur de les modifier ou tolérer des messages techniques du genre "deadlock update conflicts..."

  5. #5
    Membre expérimenté
    Avatar de Harry
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juillet 2002
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 224
    Points : 1 331
    Points
    1 331
    Par défaut
    Oui, un seul IBTransaction pour x tables, (1 par IBDatabase en fait),

    Par contre pas besoin de souffrir les messages d'erreur, il faut le paramétrer : double clique sur le compo et t'as une interface avec a droita la liste des paramètres. Si ceux-ci sont bons alors tout doit pouvoir marcher ensemble sans erreur, meme avec 6 postes en réseau.

    Voici le paramètre que j'utilise (j'ai fait de nombreux tests avant d'avoir quelquechose qui marche bien)
    read_committed
    rec_version
    nowait
    Mais il y a plein de combinaisons possible, a toi de trouver la meilleure

    Par contre il faut faire un TonIBTRansaction.Commit pour que les modifs soient appliqués a la BDD.

  6. #6
    Candidat au Club
    Inscrit en
    Octobre 2003
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Octobre 2003
    Messages : 2
    Points : 4
    Points
    4
    Par défaut
    Citation Envoyé par frantzgac
    Il faut donc toujours vérifier que l'on dispose de la main sur les données avant de proposer à l'utilisateur de les modifier ou tolérer des messages techniques du genre "deadlock update conflicts..."
    Comment on peut verifier ça ?

Discussions similaires

  1. Comment utiliser les transactions avec UIB
    Par zoheir13 dans le forum Connexion aux bases de données
    Réponses: 6
    Dernier message: 13/01/2011, 09h51
  2. Débuter avec Delphi et Interbase
    Par oussamamohamed dans le forum Bases de données
    Réponses: 6
    Dernier message: 14/09/2007, 14h02
  3. gérer les transactions avec php/sql server
    Par loukili81 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 15/05/2007, 17h39
  4. Les transactions avec TIBDatabase et TIBSQL
    Par cgone dans le forum Bases de données
    Réponses: 6
    Dernier message: 21/10/2006, 15h58
  5. Où gérer les transactions avec Firebird ?
    Par DMO dans le forum Débuter
    Réponses: 2
    Dernier message: 26/04/2005, 09h21

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