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 :

erreur dans l'exécution de la requête


Sujet :

Requêtes et SQL.

  1. #1
    Membre éprouvé
    Inscrit en
    Avril 2006
    Messages
    853
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 853
    Points : 929
    Points
    929
    Par défaut erreur dans l'exécution de la requête
    salut

    à l'exécution de ce code, j'obtiens l'erreur 3464
    Date type mismatch in criteria expression

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Dim db As Database
    Dim rs As Recordset
    Dim strSQL As String
     
    Dim strDate As Date
     
    'je lis dans un fichier une valeur que j'affecte à strDate, idem pour caisse et guichet
     
    strSQL = "select count(*) from Reception where recCaisse=" & caisse & " and recGuichet=" & guichet & " and recDateCollecte=" & "'" & strDate & "'"
     
    Set rs = db.OpenRecordset(strSQL)
    recCaisse, recGuichet sont de type text
    recDateCollecte est de type Date


    une idée?

  2. #2
    Membre expérimenté
    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
    Points : 1 664
    Points
    1 664
    Par défaut
    Salut,

    Il y a ici un problème de délimiteur:
    Si le critère est de type texte, alors le délimiteur de la valeur à comparer est le simple quote (') ou le double quote ("), c'est à dire les guillemets.
    Si le critère est de type Date et heure, le délimiteur est la dièse (#).
    Si le critère est un champ ou un contrôle d'un formulaire, alors le délimiteur est le crochet ([).
    Si c'est numérique, aucun délimiteur.
    Comme tu disais
    recCaisse, recGuichet sont de type text
    recDateCollecte est de type Date
    Alors, ton code se transforme en
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    'Ancien code
    strSQL = "select count(*) from Reception where recCaisse=" & caisse & " and recGuichet=" & guichet & " and recDateCollecte=" & "'" & strDate & "'"
                                                   
    'Nouveau code
    strSQL = "select count(*) from Reception where recCaisse Like '" & caisse & "' and recGuichet Like '" & guichet & "' and recDateCollecte=#" & strDate & "#;"
    La différence est en gras.
    Je préfère utiliser Like à la place de égale pour le texte.

    Bon courage et @+

  3. #3
    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,

    Et j'ajouterai aux explications de Mahefasoa que dans une clause where, une date doit être au format US => mm/dd/aaaa

  4. #4
    Membre expérimenté
    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
    Points : 1 664
    Points
    1 664
    Par défaut
    Re,

    Oui, et je me rejoins à pc75 pour cette remarque.
    Toutefois, il est aussi possible que les "variables" que tu utilises sont vides et dans ce cas, utilise la fonction nz pour palier ce problème.

    Bon courage et @+

  5. #5
    Membre éprouvé
    Inscrit en
    Avril 2006
    Messages
    853
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 853
    Points : 929
    Points
    929
    Par défaut
    j'obtiens error 13 type mismatch

    j'ai donc tenté de réduire la requête au minimum

    "select * from reception"

    Dim db As Database
    Dim rs As Recordset
    Dim strSQL As String
    Dim strDate As Date

    set db = currentdb()

    'future boucle ici

    strSQL = "select * from reception"
    Set rs = db.OpenRecordset(strSQL)

    'future fin de boucle

    j'obtiens alors le même message d'erreur
    pourtant aucun problème dans le modèle de requête de access...

  6. #6
    Membre éprouvé
    Inscrit en
    Avril 2006
    Messages
    853
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 853
    Points : 929
    Points
    929
    Par défaut
    en rajoutant dao devant database et recordset, ça fonctionne

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

Discussions similaires

  1. [Tomcat] configuration d'une page d'erreur dans web.xml
    Par Super Castor dans le forum Tomcat et TomEE
    Réponses: 3
    Dernier message: 08/04/2009, 15h58
  2. [Thread] Erreur dans une classe interne
    Par totof2308 dans le forum Général Java
    Réponses: 5
    Dernier message: 03/06/2004, 08h15
  3. [Lien]erreur dans mon programme python
    Par durnambule dans le forum Général Python
    Réponses: 11
    Dernier message: 29/01/2004, 14h59
  4. [Erreur dans la lib...]
    Par Gonath dans le forum OpenGL
    Réponses: 3
    Dernier message: 22/12/2003, 09h02
  5. Erreur dans l'utilisation de SWAP
    Par mire dans le forum Langage
    Réponses: 12
    Dernier message: 15/03/2003, 21h39

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