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

PHP & Base de données Discussion :

Réaliser un affichage d'articles vieux de 15 jours et à venir (90 jours) [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre émérite Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Par défaut Réaliser un affichage d'articles vieux de 15 jours et à venir (90 jours)
    salut tout le monde !

    j'ai une table 'events' avec un attribut 'start_date' et 'end_date'. Je voudrais faire une requete pour afficher les événements dont la date de fin est comprise entre 'now() - 15 jours' et 'now()' et dont la date de debut est comprise entre 'now()' et 'now()+60'. Voici ma requete (qui ne marche pas...) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $query = "SELECT title FROM table_events WHERE end_date between (\"".$day."\"-15) and now() and start_date between now() and (\"".$day."\"+90);";
    le format de la date est sous la forme : 'aaaa-mm-jj hh:mm:ss'
    avant la requete, je verifie si la date du jour est comprise entre 1 et 9, dans ce cas, j'ajoute un '0' avant. Sinon, je fais l'affectation sans '0'.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if (($i + $row)< 10 ) {
    		$day = $date['year']."-".$date['month']."-0".($i + $row);
    	}	else{
    		$day = $date['year']."-".$date['month']."-".($i + $row);}
    pourriez-vous me donner votre avis, merci bcp
    Faites une recherche sur le forum et/ou sur internet et lisez la doc officielle avant de poser une question svp.
    et n'oubliez pas de lire les FAQ !
    FAQ Java et les cours et tutoriels Java
    Doc JAVA officielle
    AngularJS 1.x
    Angular 2

    Do it simple... and RTFM !

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 278
    Par défaut
    Une possibilité, en utilisant TO_DAYS() :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $query = 'SELECT title
      FROM table_events
      WHERE end_date BETWEEN (TO_DAYS(NOW())-15) AND TO_DAYS(NOW())
        AND start_date BETWEEN TO_DAYS(NOW()) AND (TO_DAYS(NOW())+60)';

  3. #3
    Membre émérite Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Par défaut
    merci...

    mais la requete ne renvoie rien, enfin si, elle renvoie tous les evenements et sans faire le tri.
    Faites une recherche sur le forum et/ou sur internet et lisez la doc officielle avant de poser une question svp.
    et n'oubliez pas de lire les FAQ !
    FAQ Java et les cours et tutoriels Java
    Doc JAVA officielle
    AngularJS 1.x
    Angular 2

    Do it simple... and RTFM !

  4. #4
    Membre émérite Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Par défaut
    et je dois faire le tri par rapport à la variable $day. Cette variable représente une date affichée sur un calendrier. La fonctionnalité que je veux developper est l'affichage d'une infobulle avec les evenements du jour concerné, quand le curseur passe dessus.

    Merci !
    Faites une recherche sur le forum et/ou sur internet et lisez la doc officielle avant de poser une question svp.
    et n'oubliez pas de lire les FAQ !
    FAQ Java et les cours et tutoriels Java
    Doc JAVA officielle
    AngularJS 1.x
    Angular 2

    Do it simple... and RTFM !

  5. #5
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 278
    Par défaut
    Désolé, j'ai posté trop vite :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $query = 'SELECT title
      FROM table_events
      WHERE TO_DAYS(end_date) BETWEEN ((TO_DAYS(NOW())-15) AND TO_DAYS(NOW()))
        AND TO_DAYS(start_date) BETWEEN (TO_DAYS(NOW()) AND (TO_DAYS(NOW())+60))';

  6. #6
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 278
    Par défaut
    Citation Envoyé par slim
    et je dois faire le tri par rapport à la variable $day. Cette variable représente une date affichée sur un calendrier. La fonctionnalité que je veux developper est l'affichage d'une infobulle avec les evenements du jour concerné, quand le curseur passe dessus.

    Merci !
    Dans ce cas, tu remplaces les NOW() concernés par $day, à condition que $day respecte le format de date de mysql.

  7. #7
    Membre émérite Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Par défaut
    Ok, bien sur pour le remplacement de now() par $day.
    La requete ne renvoie toujours rien (testé sur phpMyAdmin).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT title
    FROM table_events
    WHERE TO_DAYS( end_date )
    BETWEEN (
    TO_DAYS( now( ) ) -60
    )
    AND TO_DAYS( now( ) )
    AND TO_DAYS( start_date )
    BETWEEN TO_DAYS( now( ) )
    AND (
    TO_DAYS( now( ) ) +90
    )
    Bon, je vais voir... merci.
    Faites une recherche sur le forum et/ou sur internet et lisez la doc officielle avant de poser une question svp.
    et n'oubliez pas de lire les FAQ !
    FAQ Java et les cours et tutoriels Java
    Doc JAVA officielle
    AngularJS 1.x
    Angular 2

    Do it simple... and RTFM !

  8. #8
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 278
    Par défaut
    Et en essayant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $query = 'SELECT title
      FROM table_events
      WHERE TO_DAYS(end_date) BETWEEN ((TO_DAYS(NOW())-15) AND TO_DAYS(NOW()))
        AND TO_DAYS(start_date) BETWEEN (TO_DAYS(NOW()) AND (TO_DAYS(NOW())+60))';

  9. #9
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 278
    Par défaut
    Es-tu sûr que des enregistrements respectent ces conditions ?

  10. #10
    Membre émérite Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Par défaut
    Désolé, ce que j'ai dis est incohérent.

    c'est la liste des événements en dessous du calendrier dont je parlais. et pas l'infobulle sur la date (en utilisant $day). Donc là pas besoin de $day, c'est now() qu'il faut utiliser, comme tu as dis.
    Néanmoins la requete sur phpMyAdmin ne renvoie rien...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    SELECT title
    FROM jos_extcal_events
    WHERE TO_DAYS( end_date )
        BETWEEN
            (TO_DAYS( NOW( ) ) -15)
            AND TO_DAYS( NOW( ) )
        AND TO_DAYS( start_date )
        BETWEEN TO_DAYS( NOW( ) )
            AND (TO_DAYS( NOW( ) ) +60);
     
    MySQL a répondu:Documentation
    #1064 - Erreur de syntaxe pr�s de 'LIMIT 0, 30' � la ligne 4
    Tanx
    Faites une recherche sur le forum et/ou sur internet et lisez la doc officielle avant de poser une question svp.
    et n'oubliez pas de lire les FAQ !
    FAQ Java et les cours et tutoriels Java
    Doc JAVA officielle
    AngularJS 1.x
    Angular 2

    Do it simple... and RTFM !

  11. #11
    Membre émérite Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Par défaut
    Citation Envoyé par vg33
    Es-tu sûr que des enregistrements respectent ces conditions ?
    oui. J'ai enregistré 2 événements le 5 et le 25 de chaque mois. Entre aout et decembre.
    Faites une recherche sur le forum et/ou sur internet et lisez la doc officielle avant de poser une question svp.
    et n'oubliez pas de lire les FAQ !
    FAQ Java et les cours et tutoriels Java
    Doc JAVA officielle
    AngularJS 1.x
    Angular 2

    Do it simple... and RTFM !

  12. #12
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 278
    Par défaut
    Les dates de fin et de début sont inversées.
    Actuellement, tu cherches les événements qui commenceront entre aujourd'hui et dans 2 mois, et qui sont finis depuis 15 jours
    Essaye donc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $query = 'SELECT title
      FROM table_events
      WHERE TO_DAYS(start_date) BETWEEN TO_DAYS(NOW())-60 AND TO_DAYS(NOW())
        AND  TO_DAYS(end_date) BETWEEN TO_DAYS(NOW()) AND TO_DAYS(NOW())+15';
    C'est beaucoup plus lisible si tu mets les dates et intervales dans l'ordre chronologique.

  13. #13
    Membre émérite Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Par défaut
    là, il retourne que l'événement de 'now()' (d'aujourd'hui).
    Ca doit etre les -15 et +30 qui "marchent" pas parce que le format de date est : "aaaa-mm-jj hh:mm:ss" Et l'opération est faite seulement sur le "jour".
    Faites une recherche sur le forum et/ou sur internet et lisez la doc officielle avant de poser une question svp.
    et n'oubliez pas de lire les FAQ !
    FAQ Java et les cours et tutoriels Java
    Doc JAVA officielle
    AngularJS 1.x
    Angular 2

    Do it simple... and RTFM !

  14. #14
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 278
    Par défaut
    Quel est ton intervale ?
    Dans l'exemple, c'est -60 jours < aujourd'hui < +15 jours.
    Et ça fonctionne chez moi.
    Si l'intervale est l'inverse, change la requête en conséquence.
    Si tu as encore un souci, poste une ligne de la table qui doit être trouvée par ta requête.

  15. #15
    Membre Expert

    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 278
    Par défaut
    Citation Envoyé par slim
    Et l'opération est faite seulement sur le "jour".
    Non. TO_DAYS() transforme une date quelconque en nombre de jours écoulés depuis le 01/01/1970 (comme un timestamp, mais en jours). Ainsi, TO_DAYS(NOW()) = 732971 (avec la date du 22/10/2006, quelle que soit l'heure).

  16. #16
    Membre émérite Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Par défaut
    Salut et merci bcp pour les réponses.

    Mon intervalle est bien :

    -15 < ajourd'hui < +60

    En utilisant la requete avec TO_DAYS, j'obtiens que les evenements de - 15 et pas de +60. Je joins la liste des événements retournés.



    et la structure de la yable events :



    Ma requete est la suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    $query = 'SELECT extid, title, start_date
      FROM jos_extcal_events
      WHERE TO_DAYS(start_date) BETWEEN TO_DAYS(NOW())-15 AND TO_DAYS(NOW())
        AND  TO_DAYS(end_date) BETWEEN TO_DAYS(NOW()) AND TO_DAYS(NOW())+60';
    Merci !
    Faites une recherche sur le forum et/ou sur internet et lisez la doc officielle avant de poser une question svp.
    et n'oubliez pas de lire les FAQ !
    FAQ Java et les cours et tutoriels Java
    Doc JAVA officielle
    AngularJS 1.x
    Angular 2

    Do it simple... and RTFM !

  17. #17
    Membre expérimenté
    Avatar de titoumimi
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    3 707
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 707
    Par défaut
    en général, pour obtenit des intervalles, j'utilise ce genre de requêtes :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $query = "SELECT title FROM table_events WHERE DATE_SUB(CURDATE(),INTERVAL 15 DAY) >= end_date AND DATE_ADD(CURDATE(),INTERVAL 60 DAY) <= start_date";
    Globalement inoffensif
    Merci de respecter les règles du forum.
    Aucune question technique par MP !
    _______________________________________________________________________
    Cours Ruby et Ruby on Rails (RoR) - Cours PHP - FAQ Ruby / Rails - Livres Ruby / Rails
    Ajax facile avec Ruby on Rails, Prototype, script.aculo.us et les RJS
    Tutoriaux HTML/CSS et PHP

  18. #18
    Membre émérite Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Par défaut
    Vraiment désolé mais la requete s'execute sans probleme mais ne renvoie absolument rien...

    Les enregistrements sont les suivants :

    - evenement 1 : du 17-05-2006 à 08:00:00 au 17-05-2006 à 23:59:59
    - evenement 2 : du 03-12-2006 à 08:00:00 au 08-12-2006 à 23:59:59
    - conférence 1 : du 29-09-2009 à 11:00:00 au 29-09-2006 à 16:00:00
    - conférence 2 : du 05-09-2009 à 08:00:00 au 10-09-2006 à 23:59:59
    - conférence 3 : du 25-09-2009 à 08:00:00 au 30-09-2006 à 23:59:59
    - conférence 4 : du 15-10-2009 à 08:00:00 au 29-10-2006 à 23:59:59

    Tanx
    Faites une recherche sur le forum et/ou sur internet et lisez la doc officielle avant de poser une question svp.
    et n'oubliez pas de lire les FAQ !
    FAQ Java et les cours et tutoriels Java
    Doc JAVA officielle
    AngularJS 1.x
    Angular 2

    Do it simple... and RTFM !

  19. #19
    Membre expérimenté
    Avatar de titoumimi
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    3 707
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 707
    Par défaut
    essayez d'inverser les > et < je suis jamais très sur de moi
    Globalement inoffensif
    Merci de respecter les règles du forum.
    Aucune question technique par MP !
    _______________________________________________________________________
    Cours Ruby et Ruby on Rails (RoR) - Cours PHP - FAQ Ruby / Rails - Livres Ruby / Rails
    Ajax facile avec Ruby on Rails, Prototype, script.aculo.us et les RJS
    Tutoriaux HTML/CSS et PHP

  20. #20
    Membre émérite Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Par défaut
    héhé !!!! que suis-je bête !

    ca marche ! merci beaucoup.
    Faites une recherche sur le forum et/ou sur internet et lisez la doc officielle avant de poser une question svp.
    et n'oubliez pas de lire les FAQ !
    FAQ Java et les cours et tutoriels Java
    Doc JAVA officielle
    AngularJS 1.x
    Angular 2

    Do it simple... and RTFM !

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Affichage d'articles sur différentes pages
    Par RougeCerise dans le forum Langage
    Réponses: 1
    Dernier message: 04/07/2008, 16h01
  2. [Joomla!] probleme d'affichage d'article
    Par pierrot10 dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 01/05/2008, 15h43
  3. Affichage d'article
    Par !Maqs dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 08/12/2007, 15h39
  4. [SQL] Réaliser un affichage de données avec possibilité de modification
    Par Adrien93 dans le forum PHP & Base de données
    Réponses: 15
    Dernier message: 03/11/2006, 01h07
  5. [MFC] Réaliser l'affichage d'un oscilloscope
    Par Racailloux dans le forum MFC
    Réponses: 7
    Dernier message: 04/03/2005, 01h52

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