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 :

Requête select avec Count en VBA, résultat dans une variable - pb de syntaxe


Sujet :

VBA Access

  1. #1
    Membre du Club
    Homme Profil pro
    Ingénieur Matériaux
    Inscrit en
    Mars 2013
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Matériaux
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2013
    Messages : 61
    Points : 61
    Points
    61
    Par défaut Requête select avec Count en VBA, résultat dans une variable - pb de syntaxe
    Bonjour à tous,

    Je cherche à faire un peu la même chose qu'ici.

    Voici comment je m'y suis pris pour obtenir le résultat d'une requête select avec un count dans une variable :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
    Dim Rassocdemech As String
    Dim RSassocdemech As DAO.Recordset
    Dim db As Database
     
    Rassocdemech = "SELECT COUNT(TJ_demandes_ech.IDJ_demande) AS nbassocdemech"
    Rassocdemech = Rassocdemech & "FROM Tdemandes INNER JOIN TJ_demandes_ech ON Tdemandes.ID_demandes = TJ_demandes_ech.IDJ_demande"
    Rassocdemech = Rassocdemech & "GROUP BY TJ_demandes_ech.IDJ_ech, Tdemandes.str_type_demande"
    Rassocdemech = Rassocdemech & "HAVING (((TJ_demandes_ech.IDJ_ech)=[Formulaires]![FDemandes]![FJ_demandes_ech].[Formulaire]![IDJ_ech]) AND ((Tdemandes.str_type_demande)=&chr(34)&Echantillons&chr(34)&));"
     
    Set db = CurrentDb
    Set RSassocdemech = db.OpenRecordset(Rassocdemech)
    seulement voila j'ai une erreur d'execution 3141 qui dit :
    Dans l'instruction SELECT, n mot réservé ou un argument est mal orthographié ou absent.

    J'ai beau chercher je ne trouve pas l'erreur, la syntaxe de la chaine SQL vient tout droit de l'éditeur de requêtes access avec une seule petite modification, l'utilisation de Chr(34) pour le ".

    Merci de votre aide.

  2. #2
    Expert confirmé
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Points : 4 047
    Points
    4 047
    Par défaut
    Bonjour,

    Il te manque un espace à la fin de ces lignes

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Rassocdemech = "SELECT COUNT(TJ_demandes_ech.IDJ_demande) AS nbassocdemech "
    Rassocdemech = Rassocdemech & "FROM Tdemandes INNER JOIN TJ_demandes_ech ON Tdemandes.ID_demandes = TJ_demandes_ech.IDJ_demande "
    Rassocdemech = Rassocdemech & "GROUP BY TJ_demandes_ech.IDJ_ech, Tdemandes.str_type_demande "
    Rassocdemech = Rassocdemech & "HAVING (((TJ_demandes_ech.IDJ_ech)=[Formulaires]![FDemandes]![FJ_demandes_ech].[Formulaire]![IDJ_ech]) AND ((Tdemandes.str_type_demande)=&chr(34)&Echantillons&chr(34)&));"

  3. #3
    Membre du Club
    Homme Profil pro
    Ingénieur Matériaux
    Inscrit en
    Mars 2013
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Matériaux
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2013
    Messages : 61
    Points : 61
    Points
    61
    Par défaut
    Merci PC75 pour cette réponse, effectivement, sans les espaces cela ne fonctionne pas.

    Il subsiste un problème, j'obtiens l'erreur suivante lors de l'execution du code :

    erreur d’exécution 3061 :

    trop peu de paramètres, 1 attendu

    Le code est maintenant le suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Rassocdemech = "SELECT COUNT(TJ_demandes_ech.IDJ_demande) AS nbassocdemech "
    Rassocdemech = Rassocdemech & "FROM Tdemandes INNER JOIN TJ_demandes_ech ON Tdemandes.ID_demandes = TJ_demandes_ech.IDJ_demande "
    Rassocdemech = Rassocdemech & "GROUP BY TJ_demandes_ech.IDJ_ech, Tdemandes.str_type_demande "
    Rassocdemech = Rassocdemech & "HAVING (((TJ_demandes_ech.IDJ_ech)=[Formulaires]![FDemandes]![FJ_demandes_ech].[Formulaire]![IDJ_ech]) AND ((Tdemandes.str_type_demande)=" & Chr(34) & "Echantillons" & Chr(34) & "));"
     
    MsgBox Rassocdemech
     
     
     
    Set db = CurrentDb
    Set RSassocdemech = db.OpenRecordset(Rassocdemech)
    les paramètres sont des valeurs de formulaires, qui sont non nulles puisque ce code s’exécute après mise à jour d'un champ.

    Merci de votre aide

  4. #4
    Expert confirmé
    Avatar de pc75
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    3 662
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2004
    Messages : 3 662
    Points : 4 047
    Points
    4 047
    Par défaut
    Re,

    - 1 - Tes variables ne sont pas interprétées. Elles sont considérées comme du texte

    - 2 - Si tes champs sont de type texte, il faut délimiter les valeurs des variables avec des simples quotes :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Rassocdemech = Rassocdemech & " HAVING MonChamp1 = '" & MaVariable1 & "' AND MonChamp2 = '" & MaVariables & "' "

  5. #5
    Membre du Club
    Homme Profil pro
    Ingénieur Matériaux
    Inscrit en
    Mars 2013
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Matériaux
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2013
    Messages : 61
    Points : 61
    Points
    61
    Par défaut
    OK,

    J'ai réussi à m'en sortir.

    Voici ce que cela donne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Rassocdemech = "SELECT COUNT(TJ_demandes_ech.IDJ_demande) AS nbassocdemech "
        Rassocdemech = Rassocdemech & "FROM Tdemandes INNER JOIN TJ_demandes_ech ON Tdemandes.ID_demandes = TJ_demandes_ech.IDJ_demande "
        Rassocdemech = Rassocdemech & "GROUP BY TJ_demandes_ech.IDJ_ech, Tdemandes.str_type_demande "
        Rassocdemech = Rassocdemech & "HAVING (((TJ_demandes_ech.IDJ_ech)=" & Forms("FDemandes").Form("FJ_demandes_ech").Controls("IDJ_ech") & ") AND ((Tdemandes.str_type_demande)=" & Chr(34) & "Echantillons" & Chr(34) & "));"
        Set db = CurrentDb
        Set RSassocdemech = db.OpenRecordset(Rassocdemech)
    Merci

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

Discussions similaires

  1. [AC-2010] INSERT SELECT avec union de 2 tables dans une nouvelle table
    Par Nikimizi dans le forum Requêtes et SQL.
    Réponses: 0
    Dernier message: 31/07/2014, 13h51
  2. [Batch] lire dans un fichier et mettre le résultat dans une variable
    Par danydan01 dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 09/06/2010, 12h28
  3. [AC-2003] Requête sql avec méthode DoCmd.Runsql bloqué dans une transaction
    Par rana dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 09/03/2010, 13h20
  4. Requète SQL avec nom de table contenu dans une variable
    Par samoussa dans le forum Langage SQL
    Réponses: 2
    Dernier message: 13/05/2009, 13h58
  5. évaluer une commande et avoir le résultat dans une variable
    Par ggnore dans le forum Scripts/Batch
    Réponses: 2
    Dernier message: 10/06/2008, 17h36

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