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 :

DATE et TIME format Mysql vs NOW() [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre éclairé Avatar de monlou
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : Canada

    Informations forums :
    Inscription : Janvier 2010
    Messages : 363
    Par défaut DATE et TIME format Mysql vs NOW()
    Bonjour,

    j'ai deux champs dans ma table:

    un en format DATE() et un autre FORMAT TIME()

    je voudrais faire en sorte de supprimer tous les enregistrements qui sont égales a NOW() AND les plus anciens

    je peux écrire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DELETE ID FROM ma_table WHERE date_depart >= NOW
    je desirerais savoir maintenant 2 choses:

    1- Est-ce que date_depart dans ma table qui est en format DATE contient les heures et les minutes pour contenir les attributs de NOW ?

    2- Est-ce que lles dates plus anciennes sont plus grand > ou plus petit < que NOW?

    merci

  2. #2
    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
    Par défaut
    Tu pouvais repondre à tes questions toi même en faisant un essai :

    1 - le type DATETIME contient la date et l'heure mais on peut faire une comparaison entre un champ DATE et un champ DATETIME.

    2 - Très evidemment date_passée < date_future
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre éclairé Avatar de monlou
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : Canada

    Informations forums :
    Inscription : Janvier 2010
    Messages : 363
    Par défaut
    merci sabotage

    Tu pouvais repondre à tes questions toi même en faisant un essai :
    il s'agissait de DELETE

    je pouvais faire un essai moi-meme mais je ne voulais pas non plus detruire des mauvaises donnees

  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
    Par défaut
    Si tu dois faire une manoeuvre délicate sur une base
    1 - fait une sauvegarde
    2 - fait d'abord le test sur une copie
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre éclairé Avatar de monlou
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : Canada

    Informations forums :
    Inscription : Janvier 2010
    Messages : 363
    Par défaut
    j'ai fait ceci mais y a rien qui se passe!!


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $del= "DELETE id FROM depart WHERE DATE_FORMAT(date_depart,'%d/%m/%Y') AS date_fr <= NOW()";
     
    $sql="SELECT DATE_FORMAT(date_depart, '%d/%m/%Y') AS date_fr,DATE_FORMAT(heure_depart,'%H:%i') AS time_depart, places_disponibles, province_depart, ville_depart,
     point_depart, province_destination, ville_destination, point_destination, prix FROM depart ORDER BY date_depart DESC";

  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
    Par défaut
    Ton DATE_FORMAT ne sert a rien.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Membre éclairé Avatar de monlou
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : Canada

    Informations forums :
    Inscription : Janvier 2010
    Messages : 363
    Par défaut
    Mais pourquoi aucun enregistrement qui correspond aux criteres ne s'effacent pas?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $del= "DELETE id FROM depart WHERE date_depart <= NOW()";

  8. #8
    Membre Expert Avatar de Madfrix
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    2 326
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 326
    Par défaut
    C'est parce qu'il s'attend à trouver une table nommée id. Tu delete forcement toute la ligne...

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $del= "DELETE FROM depart WHERE date_depart <= NOW()";

  9. #9
    Membre éclairé Avatar de monlou
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : Canada

    Informations forums :
    Inscription : Janvier 2010
    Messages : 363
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $del= "DELETE FROM depart WHERE date_depart <= NOW()";
    C'est pareil!! rien ne s'efface

  10. #10
    Membre Expert Avatar de Madfrix
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    2 326
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 326
    Par défaut
    Logiquement ca devrait marcher...

    Sinon essaies ca :

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $del= "DELETE FROM depart WHERE date_depart <= CURDATE()";

    Si ca ne marche pas, le problème vient d'ailleurs

  11. #11
    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
    Par défaut
    Et comme ça ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DELETE FROM depart WHERE date_depart <= CURDATE()
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  12. #12
    Membre éclairé Avatar de monlou
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : Canada

    Informations forums :
    Inscription : Janvier 2010
    Messages : 363
    Par défaut
    <= CURDATE()
    ca fonctionne pas non plus!!

  13. #13
    Membre Expert Avatar de Madfrix
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    2 326
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 326
    Par défaut
    le problème vient d'ailleurs alors. Peut être es tu dans une transaction ou une boucle qui ne passe jamais dans ta condition ou autre ?

  14. #14
    Membre éclairé Avatar de monlou
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : Canada

    Informations forums :
    Inscription : Janvier 2010
    Messages : 363
    Par défaut
    je me demande si le fait d'avoir convertit le format de date_depart en date_fr
    dans la boucle de la 2e requete SELECT pouurait causer le probleme sinon je ne vois pas d'autres boucles qui pouurait nuire ici.


    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
    20
    21
    22
    23
    24
    25
    26
    <?php
    $del= "DELETE FROM depart WHERE date_depart <= CURDATE()";
     
    $sql="SELECT DATE_FORMAT(date_depart, '%d/%m/%Y') AS date_fr,DATE_FORMAT(heure_depart,'%H:%i') AS time_depart, places_disponibles, province_depart, ville_depart,
     point_depart, province_destination, ville_destination, point_destination, prix FROM depart ORDER BY date_depart DESC";
    		$data = mysql_query($sql) or die('Erreur - table depart: ' . mysql_error());
    		$totalRows_data = mysql_num_rows($data);
    		$nb_lignes = 10;
    		$nb_pages = ceil($totalRows_data/$nb_lignes);
     
     
    		while($info = mysql_fetch_array($data)) {
     
    		$tableau_res[] = array('date_fr' =>htmlspecialchars($info['date_fr']),
                           'time_depart' =>htmlspecialchars($info['time_depart']),
                           'places_disponibles' => htmlspecialchars($info['places_disponibles']),
                           'province_depart' => htmlspecialchars($info['province_depart']),
    					   'ville_depart' => htmlspecialchars($info['ville_depart']),
    					   'point_depart' => htmlspecialchars($info['point_depart']),
    					   'province_destination' => htmlspecialchars($info['province_destination']),
    					   'ville_destination' => htmlspecialchars($info['ville_destination']),
    					   'point_destination' => htmlspecialchars($info['point_destination']),
    					   'prix' => htmlspecialchars($info['prix']));
    		}
     
    ?>

  15. #15
    Membre Expert Avatar de Madfrix
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    2 326
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 326
    Par défaut
    Hum...rassures moi tu fais bien un

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    mysql_query($del);

    quelque part ?

  16. #16
    Membre éclairé Avatar de monlou
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : Canada

    Informations forums :
    Inscription : Janvier 2010
    Messages : 363
    Par défaut


    et bien non

    mais la je l'ai fait et ca fonctionne comme du beurre fondu dans la poêle!!

    merci Madfrix

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

Discussions similaires

  1. format date pour importer sous mysql
    Par morgan47 dans le forum Excel
    Réponses: 2
    Dernier message: 20/02/2011, 09h43
  2. Convertir une date en format Mysql?
    Par jacko842 dans le forum VB.NET
    Réponses: 1
    Dernier message: 24/04/2010, 20h10
  3. [MySQL 5] Double tri sur date et time
    Par titoine1978 dans le forum Langage SQL
    Réponses: 8
    Dernier message: 18/06/2006, 19h46
  4. [Date] Comparer des dates au format mySQL "date
    Par Marc_P dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 25/10/2004, 15h15
  5. [date] Comparer deux formats différents
    Par terziann dans le forum Requêtes
    Réponses: 17
    Dernier message: 21/07/2003, 15h21

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