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

Requêtes et SQL. Discussion :

Problème SQL dans code VBA


Sujet :

Requêtes et SQL.

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Mars 2007
    Messages
    258
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Mars 2007
    Messages : 258
    Par défaut Problème SQL dans code VBA
    Bonjour à tous,

    Voici mon petit problème, je dois faire des stats !!
    J'ai une table incident avec différents champs date, immédiat, ....

    Voici ma requete sql :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    qr = "SELECT Count(immediat) AS Expr1 FROM tbl_incidents WHERE ((([tbl_incidents]![immediat])=True)"
            qr = qr & " AND (([tbl_incidents]![date])>=[Formulaires]![frm_stat]![txtDateDeb] And ([tbl_incidents]![date])<=[Formulaires]![frm_stat]![txtDateFin]));"
            rst.Open qr, CurrentProject.Connection, adOpenStatic
            nbimmediat = rst.Fields(0)
    En bref, je veux qu'il compte dans ma base les dossiers clôturés compris entre 2 dates qui sont définies par l'utilisateur.

    Mais il me donne un message d'erreur qui est le suivant :

    Aucune valeur donnée pour un ou plusieurs des paramètres requis.

    Pourtant il connait bien toutes les valeurs et il devrait bien me donner un résultat.

    Lorsque je copie le code et le place dans une requete, je donne la date de début et la date de fin et là, il me donne bien le bon résultat.

    Pourriez-vous me donner une idée.

    D'avance merci et bonne journée

    Benjisan

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

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

    Deux choses :

    -1- Tu as un champ nommé date => c'est un mot réservé d'Access

    -2- Dans une clause WHERE, les dates doivent être au format US

  3. #3
    Expert confirmé
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Par défaut
    Bonjour,

    je ne pense pas qu'un objet recordset soit capable de remplacer les références à un contrôle de formulaire.
    Il pense que ce sont des paramètres de la requête.
    Remplace les références au formulaire par leurs valeurs dans ta variable qr:
    Code vb : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    qr = "SELECT Count(immediat) AS Expr1 FROM tbl_incidents WHERE ((([tbl_incidents]![immediat])=True)"
    qr = qr & " AND (([tbl_incidents]![date])>=#" & Format( [Formulaires]![frm_stat]![txtDateDeb], "mm/dd/yyyy") & "# And ([tbl_incidents]![date])<=#" & Format([Formulaires]![frm_stat]![txtDateFin], "mm/dd/yyyy") &  "#));"
    A+

  4. #4
    Mou
    Mou est déconnecté
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    69
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2007
    Messages : 69
    Par défaut
    J'ao egalement le meme souci.. la date dans le Where doit obligatoirement etre format US meme si les donnes de la base sont au format Europeen ?

    J'obtiens le message d'erreur:

    Erreur d'exécution '3464':

    Type de données incompatible dans l'expression du critère

  5. #5
    Membre Expert
    Avatar de Mahefasoa
    Homme Profil pro
    Manager IT
    Inscrit en
    Octobre 2003
    Messages
    835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Manager IT

    Informations forums :
    Inscription : Octobre 2003
    Messages : 835
    Par défaut
    Bonjour,
    Citation Envoyé par Mou
    la date dans le Where doit obligatoirement etre format US meme si les donnes de la base sont au format Europeen ?
    La réponse à ta question est oui!

  6. #6
    Membre éclairé
    Inscrit en
    Mars 2007
    Messages
    258
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Mars 2007
    Messages : 258
    Par défaut Merci pour vos réponses
    Un grand merci pour vos réponse.

    En effet en regardant dans l'aide, j'ai vu que le format de la date pour les requêtes devait être au format US.

    En mettant toutes la requête que tu m'as donné, il y a une erreur de syntaxe, donc je suis passé par 2 variables var1 et var2 ou sont stockés les dates au format US.

    Voici ma requête

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    qr = "SELECT Count(immediat) FROM tbl_incidents WHERE (tbl_incidents.immediat = true) and ((tbl_incidents.date >= '" & var1 & "') and (tbl_incidents.date <= '" & var2 & "'));"
            rst.Open qr, CurrentProject.Connection, adOpenStatic
            nbimmediat = rst.Fields(0)
    Le message d'erreur est différent du précédent :

    Type de données incompatible dans l'expression du critère.

    Bizare !!! non !!

    Je vous remerci d'avance pour vos réponses

  7. #7
    Invité
    Invité(e)
    Par défaut
    Bonjour

    Quand on vous donne un exemple suivez-le.
    LedZeppII t'a donné un exemple, il faut mettre # pour les dates et non '.

    Starec

  8. #8
    Membre éclairé
    Inscrit en
    Mars 2007
    Messages
    258
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Mars 2007
    Messages : 258
    Par défaut Réponse
    Je reçois alors un message d'erreur de syntaxe

  9. #9
    Membre éclairé
    Inscrit en
    Mars 2007
    Messages
    258
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Mars 2007
    Messages : 258
    Par défaut
    Mille excuses LedZeppII, tu as tout a fais raison.
    Ca fonctionne Nickel

    Merci à tous

    PS : On est sauvé Mou

    Bonne journée à tous et à bientôt sur le forum

    Benjisan

  10. #10
    Mou
    Mou est déconnecté
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    69
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2007
    Messages : 69
    Par défaut
    Yesss. ca roule pour moi aussi. Merci encore !

    Starec> la subtilité du # n'a pas été mise en exergue non plus, donc assez difficile de s'en rendre compte... A l'avenir je ferai plus attention. Merci

  11. #11
    Membre Expert
    Avatar de Mahefasoa
    Homme Profil pro
    Manager IT
    Inscrit en
    Octobre 2003
    Messages
    835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Manager IT

    Informations forums :
    Inscription : Octobre 2003
    Messages : 835
    Par défaut
    Citation Envoyé par Mou
    Yesss. ca roule pour moi aussi. Merci encore !

    Starec> la subtilité du # n'a pas été mise en exergue non plus, donc assez difficile de s'en rendre compte... A l'avenir je ferai plus attention. Merci
    Ce n'est pas qu'il te faut faire attention, mais tout simplement il suffit de comprendre et cela devient automatique: #, ", ', [ sont des délimiteurs! Ils servent à "encadrer" ou "délimiter" des valeurs passées en papramètre dans la clause WHERE d'une requête SQL.
    • Si l'information est de type date, heure, alors # est le délimiteur;
    • Si l'information est de type texte alors " (double quote) ou ' (simple quote) est le délimiteur;
    • Si l'information est contenu dans un champ ou dans un contrôle d'un formulaire par exemple, [ (crochet) est requis;
    • Pour les autres types de données (numérique en l'occurrence), aucun délimiteur.

    Voila.
    Bon courage et @+

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

Discussions similaires

  1. [XL-2010] Modification requête SQL dans code VBA excel
    Par jgresse1025 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 11/03/2015, 22h53
  2. Problème avec SQL dans code VBA
    Par glemoin dans le forum IHM
    Réponses: 7
    Dernier message: 01/06/2014, 10h50
  3. Requête Sql dans code vba
    Par amartik dans le forum IHM
    Réponses: 1
    Dernier message: 28/01/2010, 20h21
  4. [2K8] Problème connexion sql dans "code intégré"
    Par dirakocha dans le forum SSRS
    Réponses: 0
    Dernier message: 30/07/2009, 11h17
  5. requete sql dans code vba
    Par kernel57 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 05/01/2008, 15h30

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