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

Langage Delphi Discussion :

Probléme de Violation de partage


Sujet :

Langage Delphi

  1. #1
    Membre du Club
    Inscrit en
    Avril 2010
    Messages
    134
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 134
    Points : 42
    Points
    42
    Par défaut Probléme de Violation de partage
    Bonjour,

    J'ai la procédure delphi suivante qui permet de détecter les modifications dans une table source et de les copier dans la table destination :
    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
    25
    26
    procedure TransfererEnreg(NomFichier: String) ;
    Var
    RepertSource                       : String ;
    RepertDestination                  : String ;
    RepertSourceP                      : PChar ;
    RepertDestinationP                 : PChar ;
    Result                             : Integer ;
    Result1                            : Integer ;
    SearchRec                          : TSearchRec ;
    SearchRec1                         : TSearchRec ;
    begin
    RepertSourceP                      :=   StrAlloc(100);
    RepertDestinationP                 :=   StrAlloc(100);
     
    RepertSource                       := 'W:\test\tableSou.db' ;
    RepertDestination                  := 'C:\test\tableDest.db'  ;
    Result                             := FindFirst(RepertSource , faAnyFile, SearchRec);
    Result1                            := FindFirst(RepertDestination, faAnyFile, SearchRec1);
     
        if  FileDateToDateTime(SearchRec1.Time) <> FileDateToDateTime(SearchRec.Time) then
        begin
        StrPCopy(RepertSourceP,RepertSource) ;
        StrPCopy(RepertDestinationP,RepertDestination) ;
        CopyFile(RepertSourceP,RepertDestinationP,False);   //Violation de partage si la table source est ouverte
        end ;
    end ;
    Le problème est que ca génère un problème de violation de partage lorsque la table source est en cours d'utilisation.

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Plus simplement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
        CopyFile(PChar(RepertSource),PChar(RepertDestination),False);
    Il te faut tester avant la copie si ta base est en cours d'utilisation.

  3. #3
    Membre du Club
    Inscrit en
    Avril 2010
    Messages
    134
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 134
    Points : 42
    Points
    42
    Par défaut re
    oui c'est plus simple mais ca résout pas le problème.

  4. #4
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 736
    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 736
    Points : 25 645
    Points
    25 645
    Par défaut
    utilise un TFileStream en SharedDeny, tu pourras détecter si le fichier est utilisé !
    Voir la FAQ : Tester si un fichier est déjà ouvert.

    Tu ne pourras pas contrer ce bloquage sans risque

    Des outils comme Unlocker qui le font
    Il doit y avoir des API (certaines solutions ferment le Handle d'un processus, cela doit chier des bulles après)

    Sinon ton code est d'une complexité !!!
    Sans compter les PChar, il n'est pas très rigoureux sur les libération de ressources

    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
    procedure TransfererEnreg(RepertSource, RepertDestination : String) ;
    Var
      SearchRec: TSearchRec;
      SrcTime, DestTime: TDateTime;
     
    begin
      if FindFirst(RepertSource, faAnyFile, SearchRec) then
      begin
        SrcTime := FileDateToDateTime(SearchRec.Time);
        FindClose(SearchRec); // Tu avais oublié cela !
     
        if FindFirst(RepertDestination, faAnyFile, SearchRec) then
        begin
          DestTime := FileDateToDateTime(SearchRec.Time);
          FindClose(SearchRec); 
        end
        else
          DestTime := -1;
     
        if DestTime <> SrcTime then
          CopyFile(PChar(RepertSource), PChar(RepertSource), False); 
      end;
    end;

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TransfererEnreg('W:\test\tableSou.db', 'C:\test\tableDest.db');

  5. #5
    Membre du Club
    Inscrit en
    Avril 2010
    Messages
    134
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 134
    Points : 42
    Points
    42
    Par défaut
    Merci bien shaiLeTroll,

    juste une précision, les fichier que je manipule sont des .db, .PX, .XG0, et .YG0

    je fait appelle à la même procédure 4 fois pour les 4 fichiers.

    j'ai pensé à cette manip es-ce possible :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if DestTime <> SrcTime then
    Repeat      
       Success := CopyFile(PChar(RepertSource), PChar(RepertSource), False); 
    Until   Success = True ;

  6. #6
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 736
    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 736
    Points : 25 645
    Points
    25 645
    Par défaut
    Pour copier un Dossier c'est ShFileOperation : Comment Copier un répertoire ?

    Pour moi, tu ne devrais pas copier les fichiers Paradox séparément, tu devrais copier tous les fichiers d'une table ou aucun !
    Tu risques d'avoir sur la copie une Erreur "Index Ouf of Date"

    Pense en plus que le BDE n'écrit pas les modifications dans un fichier toujours ouvert avec un TTable, souvent l'écriture réelle ne se produit que lors du Table.Close ou FlushBuffers
    Je te conseille la lecture de Paradox cookbook par SQLPro


    Si tu veux recopier ta DB, tu devrais plutôt utiliser un BatchMove
    Ou développer un module client\serveur (genre WebService, DataSnap, DCOM...) ou le client souhaitant copier les fichiers invoque une fonction du serveur qui ferme ces fichiers (donc valide leur contenu non expédié), effectue la copie, puis reprend son travail !

    La Copie de fichier DB à chaud est une très mauvaise Idée !

Discussions similaires

  1. [vb 2005]Problème de violation d'accès concurentiel
    Par estelledany dans le forum Windows Forms
    Réponses: 3
    Dernier message: 14/06/2006, 18h14
  2. Violation de partage
    Par sourivore dans le forum Autres Logiciels
    Réponses: 1
    Dernier message: 24/02/2006, 14h45
  3. suppression de fichier et violation de partage
    Par sohnic dans le forum Autres Logiciels
    Réponses: 4
    Dernier message: 21/11/2005, 11h10
  4. Problème de violation d'accès
    Par Oluha dans le forum Bases de données
    Réponses: 11
    Dernier message: 31/05/2005, 11h26

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