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] Utilisation de DAO.recordset


Sujet :

Access

  1. #1
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Février 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2006
    Messages : 126
    Points : 108
    Points
    108
    Par défaut [VBA] Utilisation de DAO.recordset
    Bonjour à tous,

    Mon problème se trouve à cette ligne


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Dim statistiques as DAO.recordset
     
    If (statistiques.EOF Or numeroStat <> Nz(statistiques("numeroSTATISTIQUE"))) Then
    Si la requete est vide, il fait un bug!!! Il n'est pas égale a null il plante tout simplement, comment éviter cela. Le NZ ne fonctionne pas!!

    Mary

  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
    Ça c'est la plaie !

    Tu peux essayer un test pour savoir si ta requète est vide :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    if not(r.EOF and r.BOF) then 
       'a priori la requète n'est pas vide -> Faire ton code
    end if
    Tu peux aussi essayer avec r.RecordCount=0 ce qui veut dire que tu n'as pas d'enr mais ce n'est pas très fiable (voir l'aide à propos de RecordCount).

    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.

  3. #3
    Membre émérite

    Profil pro
    Inscrit en
    Février 2005
    Messages
    1 751
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 1 751
    Points : 2 368
    Points
    2 368
    Par défaut Re: [VBA] Utilisation de DAO.recordset
    Bonjour le Québec (ça fait toujours plaisir ),

    Citation Envoyé par kissmytoe
    Si la requete est vide, il fait un bug!!! Il n'est pas égale a null il plante tout simplement, comment éviter cela. Le NZ ne fonctionne pas!!
    A mon avis, il s'agit plutôt d'une conséquence de l'implémentation des opérateurs logiques dans VB (Or, And...).

    Tu peux réécrire ta fonction comme suit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Dim statistiques as DAO.recordset
     
    If statistiques.EOF Then
        ' RecordSet vide, donc pas de statistiques
    ElseIf numeroStat <> Nz(statistiques("numeroSTATISTIQUE"))) Then
        ' Ici, on est sûr que le RecordSet n'est pas vide
    EndIf
    Explication:

    Dans le cas du Or, quand la partie gauche de l'expression est évaluée à Vrai, et que donc le résultat est Vrai, alors VB évalue quand même la partie droite , ce qui ne sert à rien et peut même causer une erreur .

    La preuve par l'exemple:

    Dans un module de code:
    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
    Public Sub TestLogiqueOR()
        If TestLogiqueExpr(True, "Gauche") Or TestLogiqueExpr(True, "Droite") Then
            Debug.Print "  TestLogiqueOR=" & True
        Else
            Debug.Print "  TestLogiqueOR=" & False
        End If
    End Sub
     
    Public Sub TestLogiqueAND()
        If TestLogiqueExpr(False, "Gauche") And TestLogiqueExpr(True, "Droite") Then
            Debug.Print "  TestLogiqueAND=" & True
        Else
            Debug.Print "  TestLogiqueAND=" & False
        End If
    End Sub
     
    Public Function TestLogiqueExpr(bValeur As Boolean, sLibellé) As Boolean
        Debug.Print "  ."; sLibellé; ":TestLogiqueExpr="; bValeur
        TestLogiqueExpr = bValeur
    End Function
    Dans la fenêtre de débogage:

    Taper: TestLogiqueOR
    Citation Envoyé par Résultat
    .Gauche:TestLogiqueExpr=Vrai
    .Droite:TestLogiqueExpr=Vrai
    TestLogiqueOR=Vrai
    Taper: TestLogiqueAND
    Citation Envoyé par Résultat
    .Gauche:TestLogiqueExpr=Faux
    .Droite:TestLogiqueExpr=Vrai
    TestLogiqueAND=Faux

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

Discussions similaires

  1. [VBA] utilisation de thread
    Par nemesys971 dans le forum VBA Access
    Réponses: 19
    Dernier message: 10/10/2008, 10h49
  2. [VBA] utiliser une macro contenue dans un autre classeur
    Par laloune dans le forum Macros et VBA Excel
    Réponses: 20
    Dernier message: 01/02/2006, 18h46
  3. [VBA]Utiliser les objet disponible d'un programme en VB
    Par seblefebvre dans le forum Général VBA
    Réponses: 13
    Dernier message: 01/02/2006, 10h34
  4. [EXCEL][VBA] Utilisation des formules Excel en VBA
    Par Amanck dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 27/12/2005, 15h08
  5. Bookmark de Form et de DAO.Recordset
    Par CRUSOE13 dans le forum Access
    Réponses: 4
    Dernier message: 23/06/2005, 11h27

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