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 :

Erreur 3075 - Erreur de Syntax Date dans une requete/filtre [AC-2010]


Sujet :

VBA Access

  1. #1
    Membre du Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2016
    Messages
    100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Février 2016
    Messages : 100
    Points : 49
    Points
    49
    Par défaut Erreur 3075 - Erreur de Syntax Date dans une requete/filtre
    Bonjour le forum,

    J'ai beau chercher, je ne trouve pas la solution à mon problème.
    J'aimerai filtrer un sous-formulaire qui est rempli par une requête. Le filtre porte sur des dates du style "du" "au" 01.01.2017. ou 31.01.2017
    J'ai essayé toutes version possible et inimaginable.
    Avec le critère "des dates" dans des variables, direct avec les valeurs du formulaire etc... Sans succés
    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
    Dim datedebut   As Date
    Dim datefin     As Date
    datedebut = Me.feldDvon.Value 'champdate à partir
    datefin = Me.feldDbiss.Value 'champ date jusquà
    'Me.UF_monatsAB 'C'est le sous formulaire à filtrer
    'aufbaumonatsAB 'C'est la requete qui rempli le sous formulaire
    'CreationDate ' le champ qui contient la date de création
     
    '-----------
    'Les différentes version testée
     
    'Me.UF_monatsAB.Form.Filter = "[aufbaumonatsAB].[CreationDate] Between #" & Format(Me.feldDvon, "DD/MM/YYYY") & "# And #" & Format(Me.feldDbiss, "DD/MM/YYYY") & "# "
    'Me.UF_monatsAB.Form.Filter = "[aufbaumonatsAB].[CreationDate] Between #" & Format(Me.feldDvon, "MM/DD/YYYY") & "# And #" & Format(Me.feldDbiss, "MM/DD/YYYY") & "# "
    'Me.UF_monatsAB.Form.Filter = "aufbaumonatsAB.[CreationDate] Between " & datedebut & " And " & datefin & " "
    Me.UF_monatsAB.Form.Filter = "aufbaumonatsAB.[CreationDate] Between #" & datedebut & "# And #" & datefin & "# "
    Me.UF_monatsAB.Form.FilterOn = True
    Me.UF_monatsAB.Requery
    Quelqu'un a une piste ou idée de ce qui cloche ?
    Merci

  2. #2
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Développeur VBA/C#/VB.Net/Power Platform
    Inscrit en
    Juillet 2007
    Messages
    14 594
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur VBA/C#/VB.Net/Power Platform
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 594
    Points : 34 266
    Points
    34 266
    Par défaut
    Salut;

    le format de date en SQL sous Access est le suivant : #MM/JJ/AAAA#

    Essaie avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Me.UF_monatsAB.Form.Filter = "aufbaumonatsAB.[CreationDate] Between #" & format(datedebut,"MM/dd/yyyy") & "# And #" & format(datefin,"MM/dd/yyyy") & "# "
    Me.UF_monatsAB.Form.FilterOn = True
    Cycle de vie d'un bon programme :
    1/ ça fonctionne 2/ ça s'optimise 3/ ça se refactorise

    Pas de question technique par MP, je ne réponds pas

    Mes ouvrages :
    Apprendre à programmer avec Access 2016, Access 2019 et 2021

    Apprendre à programmer avec VBA Excel
    Prise en main de Dynamics 365 Business Central

    Pensez à consulter la FAQ Excel et la FAQ Access

    Derniers tutos
    Excel et les paramètres régionaux
    Les fichiers Excel binaires : xlsb,

    Autres tutos

  3. #3
    Membre du Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2016
    Messages
    100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Février 2016
    Messages : 100
    Points : 49
    Points
    49
    Par défaut
    Merci pour la contribution, malheureusement ca coince toujours au même endroit.
    Ci-dessous le debug.print. Il a l'air correcte
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    aufbaumonatsAB.[CreationDate] Between #01.01.2017# And #02.08.2017#
    Du 01.01.2017 au 08.02.2017 en format France

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

    Dans ton titre tu mets Erreur de Syntaxe.

    Est-ce que le champ de ta table est bien au format Date ?
    Car les différentes manières d'écrire une date ne donne pas en général une erreur de syntaxe, mais une erreur d'interprétation de la date.

    Philippe

  5. #5
    Membre du Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2016
    Messages
    100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Février 2016
    Messages : 100
    Points : 49
    Points
    49
    Par défaut
    A Phillipe,
    Oui je penses que c'est un format date, meme sur car dans la table il y a heure, minute, seconde.
    Si je mets les conditions identiques dans la requete en question Style "Entre #01.01.2017# et #08.02.2017# le filtre fonctionne.
    Le sous-formulaire est basée sur une requete, à titre info.
    La procédure de filtrage sur un Bouton "Evenement click - fait ceci" et non sur un champ style "Afterupdate, change etc..."

    L'autre question qui me chiffone, dans ma requete (résultat affiché dans le sous-formulaire", il y a une fonction sur deux champs.
    Type recherche de fichier dans un repetoire
    Cela n'a peut etre rien à voir, on sait jamais. Plus il y a d'infos mieux c'est ...

  6. #6
    Invité
    Invité(e)
    Par défaut
    Re

    Au fait tu nous a pas dit quel est le message d'erreur ?

    Philippe

  7. #7
    Membre du Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2016
    Messages
    100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Février 2016
    Messages : 100
    Points : 49
    Points
    49
    Par défaut
    Nom : SnipImage.JPG
Affichages : 623
Taille : 17,3 Ko

    Erreur 3075
    Dans les grandes lignes. Erreur de syntax dans Datum (date) dans la formulation de la requete

  8. #8
    Expert éminent sénior
    Avatar de tee_grandbois
    Homme Profil pro
    retraité
    Inscrit en
    Novembre 2004
    Messages
    8 648
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Novembre 2004
    Messages : 8 648
    Points : 14 626
    Points
    14 626
    Par défaut
    Bonjour,
    j'ai reproduit l'erreur en changeant mes paramètres Windows pour avoir la date avec le format jj.mm.aaaa. Il semblerait que le souci vienne des # délimitant les dates
    . Par contre, cela passe quand on met des " comme le montre l'image jointe : l'erreur se produit sur la ligne contenant les # :

    Nom : Erreur date 3075.JPG
Affichages : 751
Taille : 39,6 Ko
    Quand on est derrière l'écran on n'a aucun clavier sous les mains ...
    ah non ? donc devant l'écran c'est la connectique ?

  9. #9
    Invité
    Invité(e)
    Par défaut
    Re

    Si cela marche avec des " c'est que le champ de la table est un champ de type texte et non date, ce que je suggérais plus haut.

    Philippe

  10. #10
    Membre du Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2016
    Messages
    100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Février 2016
    Messages : 100
    Points : 49
    Points
    49
    Par défaut
    Merci pour vos contributions.
    J'ai du mal à suivre.
    Dans la requete de base, si je mets
    Nom : SnipImage.JPG
Affichages : 628
Taille : 52,6 Ko
    Zwischen = Entre // Und = ET
    Voici le SQL
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE (((dbo_tblInvoiceRecording.CreationDate) Between #2/1/2017# And #2/8/2017#));
    Tout fonctionne

    Je fais la même chose dans mon sous formulaire <=== ca ne fonctionne pas
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Me.UF_monatsAB.Form.Filter = "aufbaumonatsAB.[CreationDate] Between #" & Format(datedebut, "MM/dd/yyyy") & "# And #" & Format(datefin, "MM/dd/yyyy") & "# "
    la seule différence que je vois, c'est que dans mon SQL de la requete, CreationDate est de la table. Et que dans mon sous-formulaire CreationDate est basé sur la requete

    Je comprends plus rien !!!

  11. #11
    Expert éminent sénior
    Avatar de tee_grandbois
    Homme Profil pro
    retraité
    Inscrit en
    Novembre 2004
    Messages
    8 648
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Novembre 2004
    Messages : 8 648
    Points : 14 626
    Points
    14 626
    Par défaut
    Citation Envoyé par Philippe JOCHMANS Voir le message
    Re

    Si cela marche avec des " c'est que le champ de la table est un champ de type texte et non date, ce que je suggérais plus haut.

    Philippe
    Bonjour Philippe,
    non je confirme que j'ai fait le test avec des vraies dates. j'ai simplement changé le format de la date dans les paramètres Windows et j'ai créé un code en prenant compte le nouveau format et là il me provoque l'erreur 3075.
    S'agirait'il d'un bug ou simplement que ce format ne fonctionne pas en VBA en tant que date ?
    @ boldair67 : peux-tu nous confirmer que tu as ce format jj.mm.aaaa dans les paramètres Windows ?
    Quand on est derrière l'écran on n'a aucun clavier sous les mains ...
    ah non ? donc devant l'écran c'est la connectique ?

  12. #12
    Membre du Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2016
    Messages
    100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Février 2016
    Messages : 100
    Points : 49
    Points
    49
    Par défaut
    @tee_grandbois : Comment faire la vérification dans windows ?

  13. #13
    Membre du Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Février 2016
    Messages
    100
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Février 2016
    Messages : 100
    Points : 49
    Points
    49
    Par défaut
    OOOOUUUUFFFF, ca marche. Voila ce que j'ai changé dans le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Me.UF_monatsAB.Form.Filter = "aufbaumonatsAB.CreationDate Between #" & Format(datedebut, "mm dd yyyy") & "# And #" & Format(datefin, "mm dd yyyy") & "# "
    Incroyable ...

    Merci pour votre aide
    Je clos

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

Discussions similaires

  1. [MySQL] Comparer des info date dans une requete SQL
    Par kaygee dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 06/01/2006, 21h56
  2. [oracle][delphi] Problème format de date dans une requete
    Par le_parrain dans le forum Bases de données
    Réponses: 1
    Dernier message: 21/07/2005, 10h12
  3. ajouter 1 mois à une date dans une requete
    Par alain.lc dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 04/04/2005, 12h05
  4. [SQL] Conditions sur une date dans une requete
    Par poufouille dans le forum Bases de données
    Réponses: 4
    Dernier message: 17/03/2004, 14h25
  5. test la valeur d'une date dans une requete
    Par TuxP dans le forum Requêtes
    Réponses: 2
    Dernier message: 07/01/2004, 14h53

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