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

VBA Access Discussion :

Remplissage zone de liste déroulante à partir d'une base de données Access distante


Sujet :

VBA Access

  1. #1
    Futur Membre du Club
    Inscrit en
    Mars 2009
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 16
    Points : 9
    Points
    9
    Par défaut Remplissage zone de liste déroulante à partir d'une base de données Access distante
    Bonjour, je suis nouveau sur ce forum et je débute dans la programmation sous Access VBA.
    Voilà, je vous explique mon problème.
    je réalise une apllication multi-utilisateurs sous Access. Par souci de sécurité (afin que les utilisateurs ne puissent pas trifouiller dans les tables) on a décider de disposer de 2 bases de données : l'une est la base de données locale (baselocale.mdb) qui sera installée sur chaque poste et qui contient tous les formulaires, l'autre est la base de données sur le serveur (baseserveur.mdb) qui contient uniquement les tables.
    le lien entre les 2 bases est réalisé grâce à un fichier (emp.ini) dans lequel on lit l'emplacement de la base. Voici le code sur ouverture d'un formulaire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
    Private Sub Form_Load()
    If Dir(Access.CurrentProject.Path & "\emp.ini") = "" Then
       MsgBox "Fichier d'emplacement non trouvé"
    DoCmd.Close
    End If
     
    Open Access.CurrentProject.Path & "\emp.ini" For Input As #1
    Input #1, emplacement
    Close #1
     
    End Sub
    et le code pour utiliser la base :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     
    Private Sub Valider_Click()
     
    Dim bd As Database
    Dim tcli As Recordset
     
    Set bd = DBEngine.Workspaces(0).OpenDatabase(emplacement & "\baseserveur.mdb")
    Set tcli = bd.OpenRecordset("client")
    MsgBox tcli![nomcli]
    End Sub
    Mon souci vient du fait que mes formulaires contiennent des zones de listes déroulantes dont le contenu est une requête ou une table.
    Ma question est comment renseigner le contenu des zones de listes de façon à ce qu'elles utilisent les tables de ma base distante (baseserveur.mdb)?

    J'ai essayé de remplir manuellement les listes, mais cela ne fonctionne pas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
     
    marequête = "SELECT...WHERE ID='" & ME.id & "'"
    set bd = DBEngine.Workspaces(0).OpenDatabase(emplacement & "\baseserveur.mdb")
    'emplacement est une variable globale déclarée dans un module et renseignée en lisant le contenu de emp.ini (il contient le dossier contenant la base baseserveur.mdb)
    set ttable = bd.OpenRecordset(marequête, db_open_dynaset)
     
    me.MalisteDéroulante.RowSourceType = "Table/Query"
    me.MalisteDéroulante.RowSource = ttable
    me.MalisteDéroulante.Requery
    merci d'avance pour votre aide précieuse.

  2. #2
    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,

    Il faut lier les tables de la base dorsale aux bases frontales.

    Tu peux lire ce tuto : Comment utiliser une application en mode multi-utilisateurs.

    Tout y est expliqué.

    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

  3. #3
    Membre expérimenté
    Homme Profil pro
    Développeur VBA Access
    Inscrit en
    Avril 2006
    Messages
    1 109
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur VBA Access

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 109
    Points : 1 535
    Points
    1 535
    Par défaut
    Bonjour,
    puisque tu fais une liaison tardive aux sources de données. Le remplissage des listes et listes modifiables peut être fait par une fonction CallBack.
    La fonction à appeler doit avoir le format :

    Public Function NomFonction (Ctrl as control, id as variant, lgn as variant, col as variant, code as variant) as variant

    cette fonction sera appelée plusieurs fois par le système pour remplir le contrôle; il faut faire un select case sur le paramètre code pour retourner les valeurs souhaitées

    code=acLBInitialize Initialisation du control => attend un retour<>0 si ok
    code=acLBOpen Donner un identifiant au control => Timer
    code=acLBGetRowCount Renvoyer le nombre de lignes
    code=acLBGetColumnCount Renvoyer le nombre de colonnes
    code=acLBGetColumnWidth Renvoyer la taille de la colonne = col
    code=acLBGetValue Renvoyer la valeur de la colonne=col, de la ligne=lgn
    code=acLBEnd Fermeture

    Il faut indiquer dans la propriété Origine source le nom de la fonction sans paramètre ni parenthèse.

    Sinon dans tes requêtes tu dois ajouter IN 'nomdufichierdistant' :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    StrSQL="SELECT * FROM Clients IN '" & emplacement & "\baseserveur.mdb'"

  4. #4
    Futur Membre du Club
    Inscrit en
    Mars 2009
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 16
    Points : 9
    Points
    9
    Par défaut
    merci à vous deux, je vais regarder ça et je vous dit ce qu'il en est.

  5. #5
    Futur Membre du Club
    Inscrit en
    Mars 2009
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 16
    Points : 9
    Points
    9
    Par défaut
    J'ai regarder le tuto : Comment utiliser une application en mode multi-utilisateurs.

    j'ai réussi à scinder ma base mais lorsque je veux me connecter à la base sur le serveur, il veut que je lui précise la source de données.
    la ligne suivante me renvoie une erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
    set bd = DBEngine.Workspaces(0).OpenDatabase(emplacement & "\baseserveur.mdb")

  6. #6
    Membre expérimenté
    Homme Profil pro
    Développeur VBA Access
    Inscrit en
    Avril 2006
    Messages
    1 109
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur VBA Access

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 109
    Points : 1 535
    Points
    1 535
    Par défaut
    Je crois que la variable db doit être déclarée :
    Il te faut la référence DAO (Microsoft DAO 3.x Object Library)

  7. #7
    Futur Membre du Club
    Inscrit en
    Mars 2009
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 16
    Points : 9
    Points
    9
    Par défaut
    Merci Ilank pour tes conseils avisés j'ai résolu le problème en utilisant ton code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    StrSQL="SELECT * FROM Clients IN '" & emplacement & "\baseserveur.mdb'"
    Et cela fonctionne sans déclarer la variable bd en DAO.Database

  8. #8
    Futur Membre du Club
    Inscrit en
    Mars 2009
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 16
    Points : 9
    Points
    9
    Par défaut
    Juste une petite question: dans une requête avec une jointure (donc avec deux tables) comment utiliser le "in $variable"?
    faut il l'utiliser comme ceci :
    "select t.truc, m.machin from truc t, machin m in variable where t.idtruc=m.idmachin" ou comme cela : "select t.truc, m.machin from truc t in variable, machin m in variable where t.idtruc=m.idmachin"

  9. #9
    Membre expérimenté
    Homme Profil pro
    Développeur VBA Access
    Inscrit en
    Avril 2006
    Messages
    1 109
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur VBA Access

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 109
    Points : 1 535
    Points
    1 535
    Par défaut
    bonjour developpeur,
    la première solution.

  10. #10
    Membre actif Avatar de le_dilem
    Homme Profil pro
    Consultant ERP
    Inscrit en
    Avril 2005
    Messages
    313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Consultant ERP

    Informations forums :
    Inscription : Avril 2005
    Messages : 313
    Points : 236
    Points
    236
    Par défaut
    la fonction ReChdom est plus simple non ?
    Je fume du thé et je reste éveillé, le cauchemar continue.

  11. #11
    Futur Membre du Club
    Inscrit en
    Mars 2009
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 16
    Points : 9
    Points
    9
    Par défaut
    merci ilank, ça marche nickel!

  12. #12
    Futur Membre du Club
    Inscrit en
    Mars 2009
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 16
    Points : 9
    Points
    9
    Par défaut
    Citation Envoyé par le_dilem Voir le message
    la fonction ReChdom est plus simple non ?
    je ne connaissait pas cette fonction qui a l'air simple à utiliser. Toutefois est-il possible de préciser "in $emplacement" (qui contient le chemin d'accès à la base sur le serveur) pour désigner la table dans laquelle on cherche les infos? Je vais regarder.
    Note : la fonction ReChDom(expression,domaine,critère)

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 04/05/2015, 12h42
  2. Créer une liste déroulante à partir d'une base de données
    Par shaiyajoueur dans le forum Android
    Réponses: 2
    Dernier message: 13/12/2012, 13h33
  3. [AC-2007] zone de liste déroulante à partir d'une table
    Par David42000 dans le forum IHM
    Réponses: 2
    Dernier message: 24/07/2009, 11h29
  4. Réponses: 3
    Dernier message: 22/03/2009, 17h47
  5. Charger une liste déroulante à partir d'une base de donnée
    Par mr_simon dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 04/07/2007, 08h32

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