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 confirmé
    Inscrit en
    Avril 2010
    Messages
    134
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 134
    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 236
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    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 236
    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.
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

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

  4. #4
    Expert éminent
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 071
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    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 : 14 071
    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');
    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

  5. #5
    Membre confirmé
    Inscrit en
    Avril 2010
    Messages
    134
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 134
    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
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 071
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    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 : 14 071
    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 !
    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. [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, 17h14
  2. Violation de partage
    Par sourivore dans le forum Autres Logiciels
    Réponses: 1
    Dernier message: 24/02/2006, 13h45
  3. suppression de fichier et violation de partage
    Par sohnic dans le forum Autres Logiciels
    Réponses: 4
    Dernier message: 21/11/2005, 10h10
  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, 10h26

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