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 :

Effacer tout, avant aujourd'hui [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 21
    Points : 12
    Points
    12
    Par défaut Effacer tout, avant aujourd'hui
    Bonjour,

    L'intitulé peut paraître étrange

    Voilà, j'ai une base de donnée SQL structuré comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    CREATE TABLE `calendar_event` (
      `event_id` mediumint(8) unsigned NOT NULL auto_increment,
      `event_date` date NOT NULL,
      `event_time` time NOT NULL,
      `event_name` varchar(100) NOT NULL,
      `event_text` text NOT NULL,
      PRIMARY KEY  (`event_id`)
    ) ENGINE=MyISAM AUTO_INCREMENT=18 DEFAULT CHARSET=latin1 AUTO_INCREMENT=18 ;
    Comme vous avez pu le remarquer c'est un calendrier où sont stockés des événements de mon calendrier et j'aimerais ajouter un système automatique que je planifierai en CRON (que j'exécuterais tous les jours à 1h du matin).

    Toutefois j'essaie de trouver LA commande PHP SQL du style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql_query("DELETE * SET event_date BEFORE now");
    afin d'effacer tous les événements dépassés avant la date actuelle (c-a-d aujourd'hui à l'heure de l'exécution du script).
    Mais j'aimerais l'aide et l'avis d'un expert en la matière, car les commandes SQL un peu complexe, j'ai un peu du mal.

    Pour info : les dates des événements sont donc stockés dans "event_date".

    Merci pour votre aide généreuse

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    182
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 182
    Points : 178
    Points
    178
    Par défaut
    pour ma part je te conseille de fonctionner avec un time() stocker dans ton champ time que tu mets en TIMESTAMP ou INT après tout...

    ensuite tu n'as qu'à faire une requête de ce type:

    $sql="DELETE FROM `table` WHERE `event_time` <=".time();
    mysql_query($sql);

  3. #3
    Membre éclairé Avatar de |PaRa-BoL
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    738
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 738
    Points : 876
    Points
    876
    Par défaut
    Cela dit la gestion des DATE avec MySQL est très bien géré
    Etant donné qu'il l'utilise déjà :

    DELETE FROM table WHERE date < NOW()

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 21
    Points : 12
    Points
    12
    Par défaut
    Merci "roduce" & "PaRa-BoL" pour vos réponses rapides

    pour ma part je te conseille de fonctionner avec un time() stocker dans ton champ time que tu mets en TIMESTAMP ou INT après tout...
    Malheureusement, je dois rester avec cette structure ...

    DELETE FROM table WHERE date < NOW()
    Donc d'après toi si j'exécute cette commande "DELETE FROM table WHERE event_date < NOW()", toutes les dates avant aujourd'hui seront effacés ? faut pas que je me trompe sinon j'me fais virer

  5. #5
    Membre éclairé Avatar de |PaRa-BoL
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    738
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 738
    Points : 876
    Points
    876
    Par défaut
    Fait un backup d'abord

    Ou alors teste en faisant une sélection et non une suppression.

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 21
    Points : 12
    Points
    12
    Par défaut
    Citation Envoyé par |PaRa-BoL Voir le message
    Fait un backup d'abord

    Ou alors teste en faisant une sélection et non une suppression.
    Oui sûr que j'vais faire un BACKUP merci

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

Discussions similaires

  1. [XL-2007] Protégée avant aujourd'hui ?
    Par Nounours1 dans le forum Macros et VBA Excel
    Réponses: 31
    Dernier message: 04/11/2012, 19h59
  2. Réponses: 4
    Dernier message: 04/01/2012, 14h50
  3. Effacer tout avant la string "options"
    Par Nympheasi dans le forum Langage
    Réponses: 4
    Dernier message: 06/10/2009, 08h59
  4. BTS Info de Gestion passé aujourd'hui question pour SQL
    Par red210 dans le forum Décisions SGBD
    Réponses: 11
    Dernier message: 29/05/2005, 14h48
  5. Pb effacer toutes les tables d'une bd access
    Par madiam2004 dans le forum Bases de données
    Réponses: 5
    Dernier message: 30/05/2004, 15h24

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