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 :

Envoi d'une requête de mise a jour avec access


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2015
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2015
    Messages : 120
    Points : 58
    Points
    58
    Par défaut Envoi d'une requête de mise a jour avec access
    Salut,
    je me demande s il y a un moyen d avoir une requete/table qui ne contient que les derniers mise a jour selon une periode donnee: tous les mois (les derniers donnees enregistrer dans une table pendant ce dernier mois par exemple mais pas tous les enregistrements) pour pouvoir l envoyer ensuite par mail , je me bloque dans la premiere partie car l envoie par mail j'arrive a le faire par la Macro :EmailDatabaseobject (EnvoyerObjetBaseDeDonnées)...

    C est peut etre compliquer ce que je demande mais est qu il y un moyen ou un autre pour le faire ou une autre proposition meme ?

    Merci d avance

  2. #2
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 371
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 371
    Points : 23 845
    Points
    23 845
    Par défaut
    Bonjour.

    As-tu une date qui permettrai de faire la sélection ?

    Si oui tu peux faire quelque chose comme :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    select [TaTable].* from [TaTable] where [TaTable].[TonChampDate] between [prmDateDebut] and [prmDateFin]

    cela va te permettre de sélectionner les enregistrements dont la date est comprise entre les 2 bornes prmDateDebut et prmDateFin.

    A+

  3. #3
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2015
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2015
    Messages : 120
    Points : 58
    Points
    58
    Par défaut
    salut oui j ai un champ de date ds une requette de selection j ai mis le critère suivant *
    Between [date ()] And [date()-30]
    pour exprimer entre la date d aujourd hui et la date d aujourd hui-30 jours et sa me demande de rentrer Date() comme parametre et Date()-30, comment je peux rectifier Svp ?

  4. #4
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2015
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2015
    Messages : 120
    Points : 58
    Points
    58
    Par défaut
    j ai trouvé sur internet que sa doit etre comme sa Between Date() And DateAdd("m",1,Date()) mais ça marche pas !!! lq requette est vide

  5. #5
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 371
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 371
    Points : 23 845
    Points
    23 845
    Par défaut
    Bonjour.

    À priori cela devrait fonctionner.

    Peux-tu poster le SQL de ta requête ?

    A+

  6. #6
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2015
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2015
    Messages : 120
    Points : 58
    Points
    58
    Par défaut
    Normalement , moi je travaille toujours avec les tableaux au niveau du champ critaria
    mais voila ce j ai Comme SQL

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT tbCostumers.Date_of_first_visit, tbCostumers.[Company name], tbCostumers.Application, tbCostumers.City, tbCountry.Country
    FROM tbCountry INNER JOIN tbCostumers ON tbCountry.ID = tbCostumers.Country
    WHERE (((tbCostumers.Date_of_first_visit) Between Date() And DateAdd("m",1,Date())))
    ORDER BY tbCostumers.[Company name];

  7. #7
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 371
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 371
    Points : 23 845
    Points
    23 845
    Par défaut
    Bonjour.

    Syntaxiquement tout semble correct.

    Essaye en enlevant le critère de date et regarde si tu as des données.
    Si tu n'a pas de données c'est un problème avec la jointure sur ta table pays. Il n'y a pas de client pour les pays existants ou les pays indiqués dans le client n'existent pas.
    Si tu as des données, remplace le critère calculé par un critère fixe (ex : #2015-01-01# et #2015-12-31#) et regarde si tu as des données
    Si oui, ajoute un champ calculé qui affiche Date() et DateAdd("m"; 1; Date()). Cela va te permettre de voir ce que Access utilise vraiment comme paramètre et de la comparer visuellement avec ce que tu as dans tes données.

    En procédant ainsi tu devrais pouvoir trouver la source de ton erreur.

    Bonne chasse au bug.

    A+

  8. #8
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2015
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2015
    Messages : 120
    Points : 58
    Points
    58
    Par défaut
    Bonjour,

    j'ai pu avoir des resultats avec >=Date()-30 et je crois que sa reviens au même .
    je sais pas encore pourquoi sa n a pas marché avec L autre syntaxe mais je me contenterai de cet alternatif

    Merci beaucoup marot.

  9. #9
    Expert éminent sénior

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 526
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Conseil, Formation, Développement - Indépendant

    Informations forums :
    Inscription : Février 2010
    Messages : 8 526
    Points : 16 463
    Points
    16 463
    Par défaut
    Bonjour
    Citation Envoyé par ensascience Voir le message
    Bonjour,

    j'ai pu avoir des resultats avec >=Date()-30 et je crois que sa reviens au même .
    je sais pas encore pourquoi sa n a pas marché avec L autre syntaxe mais je me contenterai de cet alternatif

    Merci beaucoup marot.
    Dateadd donnait la date du jour + 30 jours (1 mois), alors que là tu utilises -30

  10. #10
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2015
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2015
    Messages : 120
    Points : 58
    Points
    58
    Par défaut
    Ohh j ai pas fais attention et t as raison c est parceque sur un site de microsoft j ai trouver que c est lq syntaxe pour avoir les donnees entre la date d aujourd hui et le mois dernier :/
    existe t il une fonction opposé de dateAdd ?? pour exprimer ce je veux: (la date daujourd hui - un mois)

  11. #11
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2015
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2015
    Messages : 120
    Points : 58
    Points
    58
    Par défaut
    C est bon c est resolu il fallait que je rajoute un -1 pour avoir les donnees du mois dernier .
    Between Date() and DateAdd("m",-1,Date())

    Merci pour ton support

Discussions similaires

  1. Réponses: 3
    Dernier message: 08/02/2011, 12h09
  2. Réponses: 6
    Dernier message: 04/04/2008, 11h01
  3. Problème avec une requête de mise à jour
    Par Le Pharaon dans le forum Requêtes et SQL.
    Réponses: 9
    Dernier message: 11/07/2006, 13h16
  4. Réponses: 2
    Dernier message: 10/03/2006, 14h55
  5. Réponses: 6
    Dernier message: 29/11/2005, 20h36

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