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 :

3061 Trop peu de paramètres. 1 attendu


Sujet :

VBA Access

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 20
    Points : 18
    Points
    18
    Par défaut 3061 Trop peu de paramètres. 1 attendu
    Je sais que la question a déjà été posée mais je n'arrive pas à comprendre mon erreur
    Dans une boucle je veux vérifier s'il existe des enregistrements dans une seconde table avec le même numéro de demande .

    Table1 t_demande champ no_demande de type entier long
    Table2 t_motifs_rejet champ ref_no_demande de type entier long.
    J'obtiens le message 3061 Trop peu de paramètres. 1 attendu au niveau de la ligne
    Set oRst2 = oDb.OpenRecordset("SELECT * FROM [T_MOTIFS_REJET] where ([ref_no_demande] = mno_demande)", dbOpenDynaset).
    Lorsque j'utilise un numéro demande réel à la la place de la variable mno_demande ça fonctionne.
    Merci pour votre aide.
    Voici le 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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    Public Function fnModifierDonnees()
    Dim gstrAppTitle
    Dim mno_demande As Long
    Dim mnbdroits As Double, mnbdroitsdem As Double
    Dim mplafond As Double, mlimite As Double
    Dim mnbdroitsattribuables As Double, mnbdroitsaccordes As Double
    Dim mcategorie As String, mpacage As String
    MsgBox "C'est parti pour 2 mn et 30 secondes...", vbInformation, gstrAppTitle
    gstrAppTitle = "Calcul des droits"
    DoCmd.Hourglass True
     
    On Error GoTo Err_Handler
     
                Dim oDb As DAO.Database
     
                Dim oRst1 As DAO.Recordset
                Dim oRst2 As DAO.Recordset
     
                Set oDb = CurrentDb
     
                'On sélectionne tous les éléments de la table "t_demandeur" et on les ouvre en mode lecture et écriture
                Set oRst1 = oDb.OpenRecordset("SELECT * FROM [t_demandeur]", dbOpenDynaset)
     
    If (oRst1.RecordCount <> 0) Then
     
                            oRst1.MoveLast
     
               'Tant que l’on est pas revenu au début de la table, on boucle
     
                            While Not oRst1.BOF
     
                                    mno_demande = oRst1.Fields("no_demande").Value
                                    ' on vérifie s'il existe des enregistrements dans la table t_motif_rejets pour le no_demande considéré
                                    Set oRst2 = oDb.OpenRecordset("SELECT * FROM [T_MOTIFS_REJET] where ([ref_no_demande] = mno_demande)", dbOpenDynaset)
                                If (oRst2.RecordCount = 0) Then
     
                                    'VALORISATION DES VARIABLES SI PAS DE MOTIFS DE REJET
    ........

  2. #2
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Bonjour,

    Merci d'utiliser les balises code à l'avenir.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set oRst2 = oDb.OpenRecordset("SELECT * FROM [T_MOTIFS_REJET] where ([ref_no_demande] = mno_demande)", dbOpenDynaset)
    mno_demande est une variable VBA, elle n'est pas connue de la requête SQL. Il faut donc envoyer sa valeur et non son nom au moteur SQL

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set oRst2 = oDb.OpenRecordset("SELECT * FROM [T_MOTIFS_REJET] where ([ref_no_demande] = " & mno_demande), dbOpenDynaset)

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 20
    Points : 18
    Points
    18
    Par défaut
    Merci, ça marche en enlevant les ( après le where

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

Discussions similaires

  1. Erreur 3061 : Trop peu de paramètres.1 attendu
    Par deglingo37 dans le forum Requêtes et SQL.
    Réponses: 14
    Dernier message: 05/12/2014, 19h55
  2. Erreur 3061 Trop peu de paramètres 2 attendu
    Par pres62 dans le forum VBA Access
    Réponses: 5
    Dernier message: 22/06/2012, 12h14
  3. [AC-2007] EX 3061 ; Trop peu de paramètres. 11 attendu
    Par Bibi72 dans le forum Access
    Réponses: 2
    Dernier message: 09/01/2012, 16h10
  4. [AC-2002] erreur "3061 Trop peu de paramètres. 1 attendu"
    Par AntoineCIT dans le forum VBA Access
    Réponses: 3
    Dernier message: 08/01/2010, 13h13
  5. Problème 3061(Trop peu de paramètre. 1 attendu)
    Par francis-a dans le forum Requêtes et SQL.
    Réponses: 17
    Dernier message: 10/03/2008, 19h33

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