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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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
    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.

  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
    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))';

  7. #7
    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))';

  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
    Es-tu sûr que des enregistrements respectent ces conditions ?

  9. #9
    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 !

  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
    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 !

  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
    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 !

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

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