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

Delphi Discussion :

adoconnection transaction contrainte


Sujet :

Delphi

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    356
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2003
    Messages : 356
    Points : 133
    Points
    133
    Par défaut adoconnection transaction contrainte
    delphi 2006 , SQL server 2008, ADO

    bonjour,

    j'ai fais une procédure qui montre mon problème.
    je voulais exécuter des requêtes "insert","update" dans une base sans me préoccuper de l'ordre d'insertion, donc je désactive les contraintes, j’exécute les requêtes et je réactive les contraintes, jusque la, ça marche
    mais quand je veux mettre ça dans une transaction, ça ne marche plus...., je peux plus exécuter de requête "select" (même dans une autre adoconnection) ça fige. j'ai le showmessage('2') mais pas le showmessage('3'); (si au moment du showmessage('2'), j’exécute une requête "select" a partir d'un éditeur de requête, j'ai pas accès non plus)
    si j’enlève adoconnection_synchro.Execute('EXEC sp_msforeachtable "ALTER TABLE ? NOCHECK CONSTRAINT all"') ça marche
    si j’enlève BeginTrans , ça marche

    j'ai oublié un paramètre quelque part ?

    merci

    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
    21
    22
    23
    24
    procedure synchronise;
    var adoconnection_synchro : TADOConnection;
    begin
      adoconnection_synchro := TADOConnection.Create(nil);
      adoconnection_synchro.LoginPrompt := false;
      adoconnection_synchro.ConnectionString := 'Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=ma_base;Data Source=(local)';
      adoconnection_synchro.Connected := true;
     
      adoconnection_synchro.BeginTrans;
      try
        adoconnection_synchro.Execute('EXEC sp_msforeachtable "ALTER TABLE ? NOCHECK CONSTRAINT all"');
        showmessage('1');
        adoconnection_synchro.Execute('update table1 set [name]=''test''');
        showmessage('2');
        nb := read_i('select max(id) from clients',adoconnection_synchro));
        showmessage('3');
        adoconnection_synchro.Execute('EXEC sp_msforeachtable "ALTER TABLE ? WITH CHECK CHECK CONSTRAINT all"');
        adoconnection_synchro.CommitTrans;
      except
        on E:Exception do
         adoconnection_synchro.RollbackTrans;
      end;
      adoconnection_synchro.Free;
    end;

  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
    En Oracle, les ALTER TABLE se produisent hors Transaction

    En SYBASE, une option permet de gérer les opérations DDL comme le ALTER TABLE dans une transaction,
    le RollBack faisait même effet

    En SQL Server, proche de Sybase faudrait vérifier
    Si cela "fige", c'est comme si tu avais deux transactions et un dead lock !
    Faudrait regarder le niveau d'isolation, en SQL Server, je sais que cela peut avoir un impact notable !

    As-tu une exception ?
    Pense à rétablir la notification du déboggueur si tu l'as stoppé

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     except
        on E:Exception do
        begin 
          ShowMessage(E.Message); // utile pour débugguer et nous fournir le message d'erreur
          adoconnection_synchro.RollbackTrans;
        end;
      end;
    essaye aussi d'écrire cela en mode T-SQL, tu m'excuseras de la syntaxe approximative

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
       RecordSet := adoconnection_synchro.Execute(
        ' BEGIN ' +
        '    EXEC sp_msforeachtable "ALTER TABLE ? NOCHECK CONSTRAINT all" ; ' + 
        '    update table1 set [name]=''test'' ; ' +
        '    select max(id) from clients ; ' + 
        '    EXEC sp_msforeachtable "ALTER TABLE ? WITH CHECK CHECK CONSTRAINT all" ;  ' +
        ' END ; ' );
    faudra voir comme exploiter RecordSet générer par le SELECT MAX
    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é
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    356
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2003
    Messages : 356
    Points : 133
    Points
    133
    Par défaut
    non j'ai pas d'erreur; ça mouline.

    comme quand j'utilise un requeteur, je fais un "select", ça mouline , pareil. des que je "kill" mon appli, j'ai le resultat.

Discussions similaires

  1. Contrainte non nul et transactions dans une PS
    Par PickEpique dans le forum Développement
    Réponses: 3
    Dernier message: 30/07/2008, 15h40
  2. Contrainte d'integrité et transaction sous InnoDB
    Par Hervé Saladin dans le forum Requêtes
    Réponses: 8
    Dernier message: 11/12/2006, 22h45
  3. gestion d'erreur et de transactions....
    Par Dge dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 08/02/2006, 22h20
  4. Apropos des Transactions au sein d'un Stored Procedure
    Par Sarbacane dans le forum Connexion aux bases de données
    Réponses: 6
    Dernier message: 16/11/2004, 08h21
  5. [VB6] Affichage d'image avec qlq contraintes
    Par youri dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 21/11/2002, 14h44

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