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 :

Avoir deux variables constantes pour requétes sql


Sujet :

Requêtes et SQL.

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut Avoir deux variables constantes pour requétes sql
    Bonjour,
    j ai un petit probléme sous access 2000.
    J'utilise un formulaire pour faire des stats, avec notament une 30aine de requétes utilisant deux variables ( les memes pour toutes mes requetes) datedebut et datefin.
    A l'ouverture de mon formulaire l'application me demande 60 fois ( la valeur de datedebut et datefin ) , je souhaiterai qu elle me le demande une seule fois pour chacune des variables ( à louverture du formulaire) , en mémorisant donc les valeurs.
    Si quelqu un a une idée pour un débutant access merci d avance.

  2. #2
    Membre habitué
    Homme Profil pro
    Inscrit en
    Mai 2006
    Messages
    214
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 214
    Points : 169
    Points
    169
    Par défaut
    je vais me faire tapper dessus, mais pourquoi ne pas utiliser des variables globale

    en dessous des option compare database et option explicit(facultatif mais conseiller

    tu fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    dim datedebut as date ou integer selon le cas
    dim datefin as date ou integer selon le cas
    
    private sub Form_load()
    
    'ici tu demande à l'utilisateur les valeur à attribuer à datedebut et datefin et c'est partit...
    
    'InputBox("texte du message" , "titre")
    
    datedebut = InputBox("donnée la date de début", "date de début")
    datefin = InputBox("donnée la date de fin", "date de Fin")
    
    end sub
    dans une requete ou tu les utilise pour une selection dans le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sql = "SELECT CeQueTuVeux " & _
            "FROM taTable " & _
            "WHERE NomDeLaDateDeDebut = " & datedebut & _ si la date est un entier
            " And NomDeLaDateDeFin = #" &  datefin & ";" si la date est un entier
    
    Sinon
    
     "WHERE NomDeLaDateDeDebut = #" & datedebut "# " & _ si la date est une date
            "And NomDeLaDateDeFin = " &  datefin & "# ;"
    règle numéro 12 : toujours s'offrir une entrée charismatique !

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut
    merci pour ta réponse je vais déja essayer cela ( je t ai envoyé un mp d ailleurs)

  4. #4
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut
    j avais essayé de mettre deux champs indépendant date1 et date2 dans un premier formulaire que l utilisateur devait remplir , puis dans la procédure d ouverture de mon formulaire de requétes le code me.date1=debutdate et me.date2=findate
    En ayant déclaré debutdate et findate en variable générale.
    Mais bon il y a surement quelquechose que je ne saisis pas

  5. #5
    Membre habitué
    Homme Profil pro
    Inscrit en
    Mai 2006
    Messages
    214
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 214
    Points : 169
    Points
    169
    Par défaut
    j'ai édité mon 1er post, je te donerais une syntaxe meilleur vers 13h30
    règle numéro 12 : toujours s'offrir une entrée charismatique !

  6. #6
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut
    merci je progresse grâce à toi.
    il me reste un probléme de format sur les requetes apparement.
    Elles fonctionnent normalement et sans la variable globale ( logique vu la syntaxe ) .

    Exemple :

    SELECT Sum([Frais_1]) AS "Frais en cours"
    FROM DOSSIER
    WHERE ((([DOSSIER].[Dossier_traité])=-1) And (([DOSSIER].[Honoraire_réglé])=-1) And (([DOSSIER].[Date])>=[DateDebut] And ([DOSSIER].[Date])<=[DateFin]));

    quand je mets ta syntaxe ( + declaration globale) ca me met une incompatibilité. ( mes dates sont definies comme date abrégée avec format __/__/____ et je suis sous access2000)

  7. #7
    Membre habitué
    Homme Profil pro
    Inscrit en
    Mai 2006
    Messages
    214
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 214
    Points : 169
    Points
    169
    Par défaut
    Citation Envoyé par Talies
    merci je progresse grâce à toi.
    il me reste un probléme de format sur les requetes apparement.
    Elles fonctionnent normalement et sans la variable globale ( logique vu la syntaxe ) .

    Exemple :

    SELECT Sum([Frais_1]) AS "Frais en cours"
    FROM DOSSIER
    WHERE ((([DOSSIER].[Dossier_traité])=-1) And (([DOSSIER].[Honoraire_réglé])=-1) And (([DOSSIER].[Date])>=[DateDebut] And ([DOSSIER].[Date])<=[DateFin]));

    quand je mets ta syntaxe ( + declaration globale) ca me met une incompatibilité. ( mes dates sont definies comme date abrégée avec format __/__/____ et je suis sous access2000)
    donc tes date sont jj/mm/aaaa c bien sa??

    si c le cas je te pose une question, est-ce toi qui utilisera ta base ou quelq'un d'autre??

    car access n'utilise que le format us donc mm/dd/yyyy
    il exist une fonction format, mais je sais plus l'utiliser de tête en faite il faut que tu li=ui dise que ton champs est de format dd/mm/yyyy ou quelque chose comme sa je vérifie et fait de même tu apprendra plus
    règle numéro 12 : toujours s'offrir une entrée charismatique !

  8. #8
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut
    Je n utiliserai pas la base , d'ou des formulaires de statistiques avec pas mal de requétes déja faites pour l utilisateur .

    access me formatte automatiquement ma date en jj/mm/aaaa .
    Il a l air de gérer le mode fr sans probléme pour preuve quand je rentre une valeur à mes deux variables( sous la forme jj/mm/aaaa ) il n'y a pas de problémes et j obtiens de bons resultats.

  9. #9
    Membre habitué
    Homme Profil pro
    Inscrit en
    Mai 2006
    Messages
    214
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 214
    Points : 169
    Points
    169
    Par défaut
    si tu à mis le format en integer, change le pour le formant date.

    ensuite à ce stade il me semble que sa dépasse mon niveau de compétense désolé, faudra attendre qu'un modo ou un responsableaccess passe voir pour régler le pb la je peux plus désoler
    règle numéro 12 : toujours s'offrir une entrée charismatique !

  10. #10
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut
    Je l ai mis en Date en tout cas merci pour tout.

    Une derniére question , je me trompe peut etre de syntaxe par rapport à ton code vis à vis de ma requéte. Je dois bien mettre #"&[DateDebut]"# pour la date ? (ou #"[DateDebut]"# )


    SELECT Sum([Frais_1]) AS "Frais en cours"
    FROM DOSSIER
    WHERE ((([DOSSIER].[Dossier_traité])=-1) And (([DOSSIER].[Honoraire_réglé])=-1) And (([DOSSIER].[Date])>=#"&[DateDebut]"# And ([DOSSIER].[Date])<=[DateFin]));

  11. #11
    Membre habitué
    Homme Profil pro
    Inscrit en
    Mai 2006
    Messages
    214
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 214
    Points : 169
    Points
    169
    Par défaut
    Citation Envoyé par Talies
    Je l ai mis en Date en totu cas merci pour tout.

    Une derniére question , je me trompe peut etre de syntaxe par rapport à ton code vis à vis de ma requéte. Je dois bien mettre #"&[DateDebut]"# pour le format date ? (ou #"[DateDebut]"# )


    SELECT Sum([Frais_1]) AS "Frais en cours"
    FROM DOSSIER
    WHERE ((([DOSSIER].[Dossier_traité])=-1) And (([DOSSIER].[Honoraire_réglé])=-1) And (([DOSSIER].[Date])>=#"&[DateDebut]"# And ([DOSSIER].[Date])<=[DateFin]));
    en fait sa "doit" venir de la si tu ne le fait pas access ne peux pas savoir que dans ton code sql c'est une date. pour le AND ou tu à mis les date en laissant le code telquel
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    "And (([DOSSIER].[Date])>=#" & [DateDebut] & "# " & _
    "And ([DOSSIER].[Date])<= #" & [DateFin] & "#));"
    et à quoi te serve les paranthèse ?? en sql on en utilise uniquement pour les requète imbriqué nom??

    donc sa donerais plutôt ça pour ton WHERE
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    "WHERE [DOSSIER].[Dossier_traité]=-1 " & _
    "And [DOSSIER].[Honoraire_réglé])=-1 " & _
    "And [DOSSIER].[Date]>=#" & [DateDebut] & "# " & _
    "And [DOSSIER].[Date]<= #" & [DateFin] & "#;"
    ;"

    et là d'après moi sa d'evrais marché sinon faut attendre que quelquun d'autre s'intéraise à ton cas...
    règle numéro 12 : toujours s'offrir une entrée charismatique !

  12. #12
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut
    si quelqu un a une autre approche de la problématique, qu il n'hésite pas :p

  13. #13
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Salut,

    Où tu bute exactement et où es-tu rendu avec le code de ben_skywalker

  14. #14
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut
    j'essaye comme il l a suggéré de passer par des constantes globales.

    Pour la requete sql, Access 2000 n'accepte apparement pas la syntaxe #" & [DateFin] & "# mais seulement " & [DateFin] & "
    Quand je lance une telle requête j ai un message d erreur en retour :
    "Type de données incompatible dans l'expression du critére" et evidemment je n ai pas de resultat en sortie.

    Je teste depuis ce matin plusieurs optiques différentes mais je n arrive pas à progresser.

  15. #15
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    tu esseyé :
    Et pourquoi passé par des globales ? Si tes requêtes s'éxécutent avec un form ouvert tu peux déclarer des variables du Form ou mettre des controles cachés.

    Je crois que tu ne peux déclarer des globales que dans un module.

  16. #16
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut
    Citation Envoyé par Dolphy35
    tu esseyé :
    Et pourquoi passé par des globales ? Si tes requêtes s'éxécutent avec un form ouvert tu peux déclarer des variables du Form ou mettre des controles cachés.

    Je crois que tu ne peux déclarer des globales que dans un module.
    oui j obtiens un " erreur de syntaxe dans la date"
    Concernant ta remarque et les variables je vais essayer merci.

  17. #17
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut
    C'est quand meme bizarre..
    Ca me parassait quelque chose de classique sous access de faire un formulaire contenant plusieurs requêtes ayant deux variables de date

  18. #18
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Peux-tu mettre ta requête et nous dire ou tu l'éxécute et comment et le rendu désiré, stp.

    Sinon concernant tes variables tu as esseyé autre chaose.

  19. #19
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 11
    Points : 1
    Points
    1
    Par défaut
    La présentation est assez simple
    Un formulaire qui s ouvre avec une cinquantaire de champs dans lequel une requete s'excute dans chacun.
    Mes 50 requetes fonctionnent indépendamment. Elles contiennent entre autres les deux variables debutdate et findate.
    Mon gros probléme c'est que pour champ une fenetre s ouvre en me demandant la valeur de ces deux constantes ( 2x50 fenetres... trés fonctionnel )

    J ai essayé de mettre deux champs indépendant DebutDate et FinDate en haut de ce formulaire.Je n ai plus à l ouverture du formulaire les 100 fenetres. Par contre evidemment tous mes resultats sont à 0.En entrant les deux valeurs dans les champs et en essayant d actualiser le formulaire ( via un bouton , via une macro apres mej ) rien ne se passe.
    Il est bien spécifié qu une mise à jour se fait sauf pour les champs contenant une..... requéte

Discussions similaires

  1. Réponses: 0
    Dernier message: 17/02/2011, 18h15
  2. Avoir deux action differentes pour le meme form
    Par dearraed dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 24/03/2010, 16h08
  3. avoir deux chemins \graphicspath pour un même projet latex
    Par cecilebzh dans le forum Tableaux - Graphiques - Images - Flottants
    Réponses: 2
    Dernier message: 01/02/2010, 16h59
  4. Peut-on avoir deux fichier .htaccess pour 2 urlrewriting différents pour 1 même site
    Par JackBeauregard dans le forum Serveurs (Apache, IIS,...)
    Réponses: 3
    Dernier message: 30/09/2006, 08h35
  5. Avoir deux ip pour un même poste
    Par Michaël dans le forum Réseau
    Réponses: 8
    Dernier message: 19/07/2005, 18h59

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