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 :

Mettre la valeur d'un champ d'une table dans une variable


Sujet :

Access

  1. #1
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2014
    Messages
    92
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2014
    Messages : 92
    Points : 75
    Points
    75
    Par défaut Mettre la valeur d'un champ d'une table dans une variable
    B
    Nom : relations.jpg
Affichages : 814
Taille : 85,9 Ko
    Bonjour je vous explique
    l'image ci-dessus représente les relations de ma table
    j'ai fais le code ci-dessous
    Code VBA access : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Public Function StatutRest(Type_Lieu_Retour, Code_Lieu_Retour, Code_Lieu_Arrivée) As String
      Dim i, j As Integer
       i = 0
       If Type_Lieu_Retour = "AV" And Code_Lieu_Retour = "1" Then StatutRest = "AV1"
       If Type_Lieu_Retour = "CL" Then StatutRest = "Clients"
       If Type_Lieu_Retour = "AU" Then StatutRest = "GGE"
       If IsNull(Code_Lieu_Arrivée) = True Or Code_Lieu_Arrivée = "0" Then i = 1
       If Type_Lieu_Retour = "FR" And i = 1 Then
              StatutRest = "GGE"
           Else
              StatutRest = [T_transport].[Lieu_Vh]
        End If
    End Function
    la partie en jaune ne marche pas car je souhaite affecter à statutRest la valeur du champ Lieu_Vh de T_transport correpondant et je ne sais pas pourquoi.
    Si quelqu'un à une idée de comment resoudre ce pb je lui serai reconnaissant.

  2. #2
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Bonjour.

    C'est une histoire de visibilité des objets. Ta fonction ne connaît rien de cette table. Elle ne connaît que ses propres variables, ses paramètres et éventuellement des variables globales.
    Les tables et champs utilisés sont locaux à la requête.

    Il faut donc que tu lui fournisses l'information.

    De ce que je comprends de ta requête, la solution qui me paraît la plus simple est

    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
    Public Function StatutRest(Type_Lieu_Retour as string, Code_Lieu_Retour as string, Code_Lieu_Arrivée as variant, _
                                                      Lieu_VH as variant) As String
      Dim i, j As Integer
       i = 0
     
       If Type_Lieu_Retour = "AV" And Code_Lieu_Retour = "1" Then StatutRest = "AV1"
       If Type_Lieu_Retour = "CL" Then StatutRest = "Clients"
       If Type_Lieu_Retour = "AU" Then StatutRest = "GGE"
       If IsNull(Code_Lieu_Arrivée) = True Or Code_Lieu_Arrivée = "0" Then i = 1
       If Type_Lieu_Retour = "FR" And i = 1 Then
              StatutRest = "GGE"
           Else
              StatutRest = Lieu_Vh
        End If
     
    End Function
    En passant je te suggère d'utiliser un autre nom que "i" pour ton drapeau. "i" est généralement utilisé pour les compteurs de boucle.

    Ici je recommanderai

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dim estSansLieuArrive as boolean : estSansLieuArrive =false
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    If IsNull(Code_Lieu_Arrivée) = True Or Code_Lieu_Arrivée = "0" Then 
        estSansLieuArrive = true
    end if
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    If Type_Lieu_Retour = "FR" And estSansLieuArrive  Then
              StatutRest = "GGE"
           Else
              StatutRest = Lieu_Vh
    End If
    Cela rend ton code plus compréhensible et donc plus facile à maintenir.

    De plus j n'est pas utilisé dans ton code et Dim i, j As Integer signifie en fait Dim i as variant, j As Integer.

    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 21/01/2015, 16h10
  2. [AC-2013] Mise à jour des valeurs d'un champ zone de liste dans une table
    Par GILLES_M dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 19/03/2014, 21h00
  3. copier une table d'une BDD dans une table d'une autre BDD
    Par faniette dans le forum C++Builder
    Réponses: 2
    Dernier message: 15/05/2013, 10h17
  4. Réponses: 7
    Dernier message: 25/03/2011, 10h52
  5. [AC-2003] insert des données d'une table dans une table d'une base externe
    Par marieo dans le forum VBA Access
    Réponses: 1
    Dernier message: 30/11/2009, 14h29

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