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 :

[Débutant] Présence d'une référence (dans une table)


Sujet :

Access

  1. #1
    Nouveau membre du Club
    Inscrit en
    Juin 2006
    Messages
    94
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 94
    Points : 38
    Points
    38
    Par défaut [Débutant] Présence d'une référence (dans une table)
    Salut à tous !

    J'ai dans un formulaire un champ permettant à l'utilisateur d'entrer une référence au clavier et un bouton "Recherche".J'aimerai lors du click sur ce bouton de recherche, que le programme teste si cette référence est présente dans ma table.

    Si c'est le cas: Le champ Référence du Formulaire prend la valeur de cette référence. (Je sais faire)
    Sinon: J'affiche une MsgBox d'erreur. (Je sais faire)

    Mon problème reste de tester la présence de la dîte valeur dans ma table.

    Merci d'avance pour vos conseils !

    Cyp'

    Edit: A noter que j'ai trouvé ca dans la FAQ mais je ne suis pas sûr que ce la corresponde et que j'arrive pas à l'exploiter :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Function ExisteChamp(NomTable As String, NomChamp As String) As Boolean
    On Error GoTo err:
    Dim MCat As New ADOX.Catalog
    Dim MTable As ADOX.Table
    Dim MField As ADOX.Column
    Set MCat.ActiveConnection = CurrentProject.Connection
    Set MTable = MCat.Tables(NomTable)
    Set MField = MTable.Columns(NomChamp)
    ExisteChamp = True
    err:
    Set MCat = Nothing
    Set MTable = Nothing
    Set MField = Nothing
    End Function

  2. #2
    Membre éclairé Avatar de stéphane_ais2
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    792
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 792
    Points : 891
    Points
    891
    Par défaut
    Bonjour,

    Regarde du côté de la Fonction 'DLookup'....

    SE
    Si le monde explose, la dernière voix audible sera celle d’un expert, disant que la chose est impossible. - P. Ustinov

  3. #3
    Nouveau membre du Club
    Inscrit en
    Juin 2006
    Messages
    94
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 94
    Points : 38
    Points
    38
    Par défaut
    Je veux bien mais le DLookUp me permet pas de faire un test non ?

    Par exemple si la valeur n'existe pas dans la table, comment réaliser un test pour qu'en cas de non-existence, ma msgbox s'affiche ?

  4. #4
    Membre éclairé Avatar de stéphane_ais2
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    792
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 792
    Points : 891
    Points
    891
    Par défaut
    Et ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    If IsNull(DLookup("[NomChamp]", "[table]", "[NomChamp]=" & Forms![NomFrm]![NomContrôle])) Then
    ...
    Non..?

    SE
    Si le monde explose, la dernière voix audible sera celle d’un expert, disant que la chose est impossible. - P. Ustinov

  5. #5
    Membre éclairé Avatar de stéphane_ais2
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    792
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 792
    Points : 891
    Points
    891
    Par défaut
    Sinon il y a la méthode 'FindFirst'...

    SE
    Si le monde explose, la dernière voix audible sera celle d’un expert, disant que la chose est impossible. - P. Ustinov

  6. #6
    Nouveau membre du Club
    Inscrit en
    Juin 2006
    Messages
    94
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 94
    Points : 38
    Points
    38
    Par défaut
    Ce code fonctionne avec le cas "Trouvé" mais pas le cas inconnu :

    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
    Private Sub Search_Click()
     
    Dim MySrch As String
    Dim MyTest As Boolean
     
    MySrch = DLookup("[Part Number]", "ZLT Tools", "[Part Number]='" & SrTxt & "'")
    MyTest = IsNull(MySrch)
     
    If MyTest = True Then
    MsgBox "This Tool (" & SrTxt.Value & ") wasn't found !!", vbExclamation, "Error"
    SrTxt.Value = ""
    Else
    PNTxt = SrTxt
    Extracting
    SrTxt.Value = ""
    End If
     
    End Sub
    Pourtant, d'aprés ce que je comprend de ce que j'ai codé... Je recherche une valeur qui correspond à mon champ de recherche par le DLookUp... Si il en trouve pas, forcement MySrch est Null non ? Donc mon IsNull devrait retourner du True non ?

  7. #7
    Nouveau membre du Club
    Inscrit en
    Juin 2006
    Messages
    94
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 94
    Points : 38
    Points
    38
    Par défaut
    Problème résolu avec un code de ce type :

    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
    Dim MySrch
    Dim MyTest As Boolean
     
    'Search for a matching PN
     
    MySrch = DLookup("[Part Number]", "ZLT Tools", "[Part Number]='" & SrTxt & "'")
    MyTest = IsNull(MySrch)
     
    If MyTest = True Then
    MsgBox "This Tool (" & SrTxt.Value & ") wasn't found !!", vbExclamation, "Error"
    SrTxt.Value = ""
    Else
    PNTxt = SrTxt
    Extracting
    SrTxt.Value = ""
    End If
    Le DLookUp ayant des problèmes avec le Null, il faut en fait définir le résultat du DLookUp sans type. Et ensuite tester un Null.

    Merci, j'espère que ca pourra servir ^^

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

Discussions similaires

  1. [XL-2007] Afficher une checkbox dans une feuille si une checkbox d'une autre feuille est cochée
    Par JessieCoutas dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 18/08/2009, 13h35
  2. portée d'une variable dans une fonction dans une méthode
    Par laurentg2003 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 29/06/2009, 19h05
  3. [POO] dans une classe, appeler une fonction dans une méthode
    Par arnaudperfect dans le forum Langage
    Réponses: 3
    Dernier message: 26/08/2007, 23h04
  4. Envoyer une formulaire dans une page dans une Frame
    Par zooffy dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 29/06/2007, 10h13
  5. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48

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