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

Access Discussion :

[VBA] empecher lancement de plusieurs instances de la BD


Sujet :

Access

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    235
    Détails du profil
    Informations personnelles :
    Localisation : Luxembourg

    Informations forums :
    Inscription : Juillet 2006
    Messages : 235
    Points : 176
    Points
    176
    Par défaut [VBA] empecher lancement de plusieurs instances de la BD
    Bonjour,

    J'ai utilisé le code contenu dans la FAq mais malheuresment cela ne fonctionne que sur la meme machine.

    Je chercher à réaliser la meme chose mais sur un réseau

    Je voudrais que si la base est déjà ouverte et q'une autre personne essaye de l'ouvrir, alors message d'erreur puis fermeture de la base pour la personne en question


    Merci

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    481
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 481
    Points : 165
    Points
    165
    Par défaut Question complémentaire
    Salut,

    En fait je n'ai pas la réponse, mais en étendant un peut la question, peut on limiter le nombre de personnes connectées en même temps ? Par exemple à 5 ou 10 ?

    Par avance merci.

    Marco en passant qui espère ne pas abuser.

  3. #3
    Expert éminent sénior
    Avatar de Domi2
    Homme Profil pro
    Gestionnaire
    Inscrit en
    Juin 2006
    Messages
    7 194
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : Suisse

    Informations professionnelles :
    Activité : Gestionnaire
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 194
    Points : 16 040
    Points
    16 040
    Par défaut
    Bonjour,

    Je dirai oui.

    Il est possible de compter le nombre d'utilisateur connecté à la base.

    Donc, en testant au lancement de l'application le nombre de connexions déjà en cours, on pourrait empêcher une nouvelle connexion.

    Il y'a peut-être d'autres solutions plus simple...

    Domi2
    Vous avez des montres, nous avons le temps ! (citation attribuée à L.-S. Senghor)

    Ici, on ne perd pas de temps ! On en passe...


    Access : créer des codes-barres 128 en VBA
    Access : les commandes intégrées des menus

    Ce message (ou un autre) vous a aidé ? Votez pour lui avec

  4. #4
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 399
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 399
    Points : 2 221
    Points
    2 221
    Par défaut
    Bonjour,

    si vous passez par la méthode consistant à compter le nombre de connexion à la base distante, voici 2 fonctions possibles qui sont sur le site :

    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
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
     
    ' Retourne le nombre d'utilisateurs connectés à une base
    ' Moins Propre que CountConnexions (voir plus loin) mais pas besoin d'ADO
    Public Function CountConnexion(ByVal sPathMdb As String) As Integer
    On Error GoTo errortag
       Dim iHandle As Integer
       Dim tUser As tConnected
     
       ' chemin du fichier LDB de la base
       sPathMdb = Left(sPathMdb, InStrRev(sPathMdb, ".")) + "ldb"
       iHandle = FreeFile
       CountConnexion = 0
     
       ' Ouvrir le LDB
       Open sPathMdb For Binary Access Read Shared As iHandle
     
       ' Lire le LDB
       Do While Not EOF(iHandle)
          ' Compte les enregistrements lus
          Get iHandle, , tUser
          If tUser.byComputer(0) <> 0 And tUser.byUser(0) <> 0 Then
             CountConnexion = CountConnexion + 1
          End If
       Loop
    fin:
       Close iHandle
       Exit Function
    errortag:
       CountConnexion = -1
       MsgBox "Erreur : " & Err.Number
       Resume fin
    End Function
     
     
    ' Nécessite en référence Microsoft ActiveX Data Objects 2.x library
    ' Par ADO, compte aussi cette connexion !
    Public Function CountConnexions(sPathMdb As String) As Long
    On Error GoTo errortag
        Dim oCn As ADODB.Connection
        Dim oRs As ADODB.Recordset
     
        Set oCn = New ADODB.Connection
        oCn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & sPathMdb
        ' The user roster is exposed as a provider-specific schema rowset
        ' in the Jet 4 OLE DB provider.  You have to use a GUID to
        ' reference the schema, as provider-specific schemas are not
        ' listed in ADO's type library for schema rowsets
        Set oRs = oCn.OpenSchema(adSchemaProviderSpecific, , "{947bb102-5d43-11d1-bdbf-00c04fb92675}")
     
        CountConnexions = 0
        If Not oRs.EOF And Not oRs.BOF Then
          oRs.MoveFirst
          Do
             CountConnexions = CountConnexions + 1
             oRs.MoveNext
          Loop Until oRs.EOF
        End If
    fin:
       Set oRs = Nothing
       Set oCn = Nothing
       Exit Function
    errortag:
       CountConnexions = -1
       MsgBox "Erreur : " & Err.Number
       Resume fin
    End Function
    Vérifier que si un utilisateur quitte pas proprement l'application, sa connexion risque de rester active et donc fausser le résultat...

    Philippe

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    235
    Détails du profil
    Informations personnelles :
    Localisation : Luxembourg

    Informations forums :
    Inscription : Juillet 2006
    Messages : 235
    Points : 176
    Points
    176
    Par défaut
    Merci pour vos réponses

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

Discussions similaires

  1. Lancement de plusieurs instances de l'application
    Par atha2 dans le forum Android
    Réponses: 13
    Dernier message: 14/10/2013, 17h08
  2. Réponses: 9
    Dernier message: 24/08/2012, 16h26
  3. [AC-2010] Eviter le lancement de plusieurs instances de mon application
    Par JeanYves70 dans le forum VBA Access
    Réponses: 17
    Dernier message: 11/04/2011, 02h05
  4. Réponses: 9
    Dernier message: 10/05/2007, 10h56
  5. empecher plusieurs instances de s'executer
    Par latoye dans le forum Bases de données
    Réponses: 1
    Dernier message: 12/03/2007, 12h38

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