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 :

Verrouillage enregistrements dBase


Sujet :

Bases de données Delphi

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2008
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 35
    Points : 22
    Points
    22
    Par défaut Verrouillage enregistrements dBase
    En Delphi 5 (version entreprise), comment savoir si un enregistrement d'une table
    dBase 5 est verrouillé par un autre utilisateur. Merci.

  2. #2
    Membre actif Avatar de liazidf
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations forums :
    Inscription : Mai 2002
    Messages : 281
    Points : 261
    Points
    261
    Par défaut verroullage de tables
    salut,
    vous auriez, appuyez sur la touche , et voilà la réponse

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Syntaxe Delphi :
     
    procedureLockTable(LockType:TLockType);
    bon courage

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2008
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 35
    Points : 22
    Points
    22
    Par défaut ???
    Merci, mais la méthode LockTable sert à vérouiller une table (si j'ai bien compris), moi je cherche juste à savoir si l'enregistrement que je voudrais modifier n'est pas au même moment modifié par un autre utilisateur, et cela avant de faire mon Edit (et si possible sans passer par une exception). Merci.

  4. #4
    Membre chevronné

    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    1 519
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 1 519
    Points : 2 153
    Points
    2 153
    Billets dans le blog
    1
    Par défaut
    La propriété Exclusive a l'air intéressante (merci "voir ausssi"). Mais c'est vrai que ça tourne toujours autour du verrouillage d'une table. Si vous utilisez ADO, les propriétés LockType et FilterGroup ont l'air intéressantes aussi.
    La FAQ - les Tutoriels - Le guide du développeur Delphi devant un problème

    Pas de sollicitations techniques par MP -

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2008
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 35
    Points : 22
    Points
    22
    Par défaut
    Citation Envoyé par Aka Guymelef Voir le message
    La propriété Exclusive a l'air intéressante (merci "voir ausssi"). Mais c'est vrai que ça tourne toujours autour du verrouillage d'une table. Si vous utilisez ADO, les propriétés LockType et FilterGroup ont l'air intéressantes aussi.
    Ca ne fonctionne pas. Merci quand même.

  6. #6
    Membre éclairé Avatar de freud
    Homme Profil pro
    Développeur
    Inscrit en
    Mai 2002
    Messages
    1 271
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Mai 2002
    Messages : 1 271
    Points : 681
    Points
    681
    Par défaut
    Bonsoir,

    Je ne sais pas si cette fonction fait l'affaire pour une table dBase :
    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
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
     
    Delphi Examples: DbiIsRecordLocked
     
    Checks the lock status of the current record. 
     
    This example uses the following input:
     
      IsRecordLocked(Table1, True);
     
     
     
    NOTE: If ByAnyone is true, then the function also checks if any other session has the record locked. If ByAnyone is false, then only the current session is checked. The function returns False if not locked, and True if locked. 
     
    The function is:
     
    function IsRecordLocked(Table: TTable; ByAnyone: Boolean): Boolean;
     
    var
      Locked: BOOL;
      hCur: hDBICur;
      rslt: DBIResult;
    begin
      Table.UpdateCursorPos;
      // Is the record locked by the current session...
      Check(DbiIsRecordLocked(Table.Handle, Locked));
      Result := Locked;
      // If the current session does not have a lock and the ByAnyone varable is
      // set to check all sessions, continue check...
      if (not Result) and (ByAnyone) then begin
        // Get a new cursor to the same record...
     
        Check(DbiCloneCursor(Table.Handle, False, False, hCur));
        try
          // Try and get the record with a write lock...
          rslt := DbiGetRecord(hCur, dbiWRITELOCK, nil, nil);
          if (rslt <> DBIERR_NONE) then begin
            // if an error occured and it is a lock error, return true...
            if (HiByte(rslt) = ERRCAT_LOCKCONFLICT) then
              Result := True
            else
              // If some other error happened, throw an exception...
     
              Check(rslt);
          end
          else
            // Release the lock in this session if the function was successful...
            Check(DbiRelRecordLock(hCur, False));
        finally
          // Close the cloned cursor...
          Check(DbiCloseCursor(hCur));
        end;
      end;
    end;
    C'est dans le BDE.HLP et faut pas oublier d'inclure l'unité BDE dans le uses
    Si quelqu'un t'a offensé, ne cherche pas à te venger; assieds-toi au bord de la rivière et, bientôt, tu verras passer son cadavre.

    Lao Tseu - un sage chinois

    Celui qui lutte contre les monstres doit veiller à ne pas le devenir lui-même.
    Et quand ton regard pénètre longtemps au fond d'un abîme, l'abîme, lui aussi, pénètre en toi.

    Friedrich Nietzsche - Par délà le bien et le mal

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2008
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 35
    Points : 22
    Points
    22
    Par défaut Ok Merci

    Ca fonctionne. Merci beaucoup.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Verrouillage Enregistrment BDD
    Par bellak dans le forum Entity Framework
    Réponses: 10
    Dernier message: 10/11/2010, 19h32
  2. Verrouillage enregistrement modifié
    Par langevert dans le forum Modélisation
    Réponses: 1
    Dernier message: 02/11/2007, 10h28
  3. Réponses: 3
    Dernier message: 27/10/2006, 15h28
  4. option verrouillage des enregistrements
    Par micig dans le forum Access
    Réponses: 2
    Dernier message: 14/04/2006, 22h52
  5. Verrouillage d'enregistrement.
    Par anikeh dans le forum Access
    Réponses: 8
    Dernier message: 26/10/2005, 15h27

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