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 :

[SQL] calcul date future


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de urbalk
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    135
    Détails du profil
    Informations personnelles :
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Novembre 2005
    Messages : 135
    Par défaut [SQL] calcul date future
    Bonjour,

    Dans une requete sql, je cherche a afficher les posts J+30. dans ma base j'ai un champs "timestamp".

    la requete sql est elle la meilleur solution ?

    Comment calculer cette date ?

    je me suis pencher sur DATEDIFF mais bon résultat.

    merci.

  2. #2
    Membre Expert Avatar de Amara
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    2 688
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 688
    Par défaut
    Citation Envoyé par urbalk
    je me suis pencher sur DATEDIFF mais bon résultat.


    On peut la voir la requête ?

  3. #3
    Membre confirmé Avatar de urbalk
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    135
    Détails du profil
    Informations personnelles :
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Novembre 2005
    Messages : 135
    Par défaut
    la voila

    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
    18
    19
     
    echo 'calcul d une date de plus de 90 jrs';
    echo '<br>';
    $today = date('Y-m-d');
    echo $today;
    echo '<br>';echo '<br>';echo '<br>';
     
    $sql = "SELECT * FROM messages 
    		WHERE datevent >= CURRENT_DATE()
    		AND DATEDIFF($today, !!!!!)
    		ORDER BY ASC";
     
    // j'envoie la requête
    $req = mysql_query($sql) or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error());
     
    //boucle dans la table
     
    // affichage des resultats
    ?>
    mon pb est au niveau des !!! je ne sais pas comment calculer l'expression 2

    a+

  4. #4
    Membre Expert Avatar de Amara
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    2 688
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 688
    Par défaut
    C'est ton champ qu'il faut mettre nan

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    sql = "SELECT * FROM messages 
    		WHERE datevent >= CURRENT_DATE()
    		AND DATEDIFF(dateevent, CURRENT_DATE()) < 30
    		ORDER BY ASC";
    Et au passage ça sert à rien d'utiliser $today, tu mets CURRENT_DATE() dans ta requête directement ça sera mieux

    (pas testé la requête)

  5. #5
    Membre confirmé Avatar de urbalk
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    135
    Détails du profil
    Informations personnelles :
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Novembre 2005
    Messages : 135
    Par défaut
    C'est ton champ qu'il faut mettre nan
    je ne pense pas car mon champs datevent correspond a un evenement qui peu avoir lieu dans 6 mois or le but de cette requete est de faire afficher tous les enregistrements qui vont avoir lieu avant 90 jours...
    Et au passage ça sert à rien d'utiliser $today, tu mets CURRENT_DATE() dans ta requête directement ça sera mieux
    en effet en fait je tatonne et essaies un peu tout

    (pas testé la requête)
    si si, d'ailleurs il y a une parse error on line 3 ;o)

    a+

  6. #6
    Membre Expert Avatar de Amara
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    2 688
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 688
    Par défaut
    Citation Envoyé par urbalk
    je ne pense pas car mon champs datevent correspond a un evenement qui peu avoir lieu dans 6 mois or le but de cette requete est de faire afficher tous les enregistrements qui vont avoir lieu avant 90 jours...
    Bah justement DATEDIFF(dateevent, CURRENT_DATE()) < 30 va te filtrer tous les enregistrements qui ont un dateevent antérieur à la date du jour + 30 jours c'est pas ça que tu voulais (et avec le dateevent >= CURRENT_DATE() en plus tu va te retrouver avec tous les enregistrements ayant un dateevent compris entre J et J+30)...

    Pour le test je voulais dire que la requête que j'ai balancé je l'ai pas testée

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

Discussions similaires

  1. [SQL] Calcul du nombre de mois entre deux dates
    Par Lolie11 dans le forum Langage SQL
    Réponses: 7
    Dernier message: 09/03/2009, 11h46
  2. [T-SQL] Calcul de date
    Par plutonium719 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 01/09/2008, 17h17
  3. Réponses: 5
    Dernier message: 30/11/2007, 17h13
  4. [Dates] calculer une date future
    Par arti2004 dans le forum Langage
    Réponses: 3
    Dernier message: 02/07/2007, 19h12
  5. vba calcul Date sql et formulaire
    Par langelot222 dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 14/06/2007, 16h19

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