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 :

Fonction Date et calcul de Date anterieurs [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    277
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 277
    Points : 64
    Points
    64
    Par défaut Fonction Date et calcul de Date anterieurs
    Bonsoir,

    Je suis un peu coincé. Je suis en PHP et je n'arrive pas a construire une requête SQL (sous MySQL) pour ramener tous les enregistrements d'une table vieux d'une date X, X pouvant être une semaine, 1 mois, 6 mois, une année, 3 ans et tous). Ca ne m'avais pas l'air très dur jusque au moment où j'ai mis les main dedans.

    Autrement dit: Dans une table j'ai une date X et je veux ramener tous ceux qui sont antérieurs a une certaine période : de 1semaien à 3 ans ou tous.

    j'ai essayé
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    Select * from ma_table WHERE date < X
    En fait je n'arrive pas en PHP a trouver une fonction qui me donne la date (variable X dans ma requête) d'il y a une semaine, 1 mois, 6 mois, une années, 3 ans etc.

    Merci.

  2. #2
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    277
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 277
    Points : 64
    Points
    64
    Par défaut
    J'ai fait ca pour les dates:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $time = mktime(date("H"), date("i"), date("s"), date("m")-1, date("d"), date("Y")); // Month - 1
    $mydate = date("d/m/Y", $time);

    Ca l'air de fonctionner.

  3. #3
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Salut,

    PHP embarque nativement tout ce qu'il faut pour manipuler les dates simplement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $a = new \DateTime('last week');
    $b = new \DateTime('last month');
    $c = new \DateTime('-6 month');
    $d = new \DateTime('last year');
    $e = new \DateTime('-3 year');
    ensuite ce n'est qu'une question de formatage :
    Voici tous les formats supportés : ici

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Sans oublier que mysql le fait aussi.
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM ma_table WHERE ma_date < DATE_SUB(ma_date, INTERVAL 1 MONTH)
    Tu n'as pas beaucoup cherché.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    277
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 277
    Points : 64
    Points
    64
    Par défaut
    Pour répondre à Sobotage, oui, je n'ai pas beaucoup cherché, il était tard hier soir lorsque j'ai posté. J'aurais du faire un effort.

    Merci a ceux qui m'ont répondu. Vos réponses en SQL et en PHP sont très élégantes.

    J'ai lu la doc sur MySQL et le Champ de type Date ne supporte qu'un seul format aaaa-mm-jj (anné, mois, jour). Y a pas moyen de faire jj-mm-aaaa ?

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Le matin non plus tu ne cherches pas trop
    STR_TO_DATE() avec Mysql
    date_create_from_format() en PHP. 5.3
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    277
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 277
    Points : 64
    Points
    64
    Par défaut
    OK merci. Tu va encore dire que je n'ai pas cherché, mais là, tu vas te tromper. J'ai cherché, mais je ne dois pas être doué.

    Mon problème est dans l'utilisation de la fonction SQL DATE_SUB.

    J'ai construit la requête suivante:

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM evaluation WHERE date > DATE_SUB (date, INTERVAL 6 MONTH)

    où 'evaluation' est le nom d'une de mes tables et 'date' un champs de type DATE (MySQL). J'ai essayé < a la place de < (illogique), j'ai essayé plein de truc mais DATE_SUB ne fonctionne pas. Pourtant j'ai bien des dates 2013-07-22, 2012-08-03, 2010-08-03, etc.. J'ai essayé avec des interval plus grand comme 1 YEAR, 2 YEAR, etc. Ca ne fonctionne pas. La requête SQL ramène tous.

  8. #8
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    277
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 277
    Points : 64
    Points
    64
    Par défaut
    Je m'auto réponds. J'ai remplacé date par CURDATE() dans la fonction DATE_SUB et c'est OK. Pourtant j'avais bien cherché avant de poster.

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

Discussions similaires

  1. [XL-2013] Calcul de dates comprises entre deux dates
    Par Goemanne dans le forum Excel
    Réponses: 2
    Dernier message: 12/03/2015, 13h10
  2. Calculer des dates avec fonction Gel de temps
    Par maxdata dans le forum Langage
    Réponses: 4
    Dernier message: 06/12/2012, 13h01
  3. Fonction de domaine - Calcul de cumul avec filtre "date et heure".
    Par Fabrice7627 dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 25/08/2007, 05h16
  4. Réponses: 2
    Dernier message: 21/03/2007, 16h06
  5. fonction en excel : calcul sur date
    Par bertrand_declerck dans le forum Excel
    Réponses: 1
    Dernier message: 06/11/2006, 13h02

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