Requète UPDATE [Résolu] - PHP

Requète UPDATE Requète UPDATE SQL boléen (Résolu) » Forum - MySQL Requête UPDATE pdo (Résolu) » Forum - PHP Requête UPDATE ajoute des entrées (Résolu) » Forum - PHP Requete UPDATE sql/php (Résolu) » Forum - PHP Probleme requete UPDATE (Résolu) » Forum - MySQL

Bonjour,
J'ai fait une requête pour que toutes les valeurs d'une colonne changent au 01 Janvier de chaque année. Je l'ai testé dans PhpMyadmin et elle fonctionne mais je l'a trouve quelque peu simpliste. Pouvez-vous me dire si on peut faire mieux.
Je vous remercie.

 //remettre le champ "mail" à 0 au 1er Janvier de chaque année function set_mail_changed() {     $sql = "UPDATE cdc_personnes SET mail = 0             WHERE '01-01'";      return executeQuery($sql); } 

Forum

Requète UPDATE Requète UPDATE SQL boléen (Résolu) » Forum - MySQL Requête UPDATE pdo (Résolu) » Forum - PHP Requête UPDATE ajoute des entrées (Résolu) » Forum - PHP Requete UPDATE sql/php (Résolu) » Forum - PHP Probleme requete UPDATE (Résolu) » Forum - MySQL

Web: www.shapebootstrap.net

30 réponses

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Bonjour
Ton where ne sert à rien.
Par contre... Tu dois mettre ça dans une tâche cron exécutée le 1e r janvier.

Reply

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Bonjour,
J'ai créé la tache CRON pour demain je vais voir si c'est bon. Par contre je me pose une question, étant donné que j'ai créé deux taches CRON qui font appel au même chemin absolu, il risque pas d'avoir un conflit en fait?
Merci

Reply
réponses:
  • jordane45

    Tu as créés 2 scripts différents bien-sûr ?!

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

oui mais c'est dans la même page.

Reply
réponses:
  • jordane45

    Pas possible

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Bonjour,
Ok c'est ce qui me paraissait pas normal. Mais alors créé une page uniquement pour une requète c'est dommage. Pouvons nous pas faire une requète UPDATE avec une clause WHERE avec une date définie?
Je te remercie.

Reply
réponses:
  • jordane45

    Pas de clause where
    Mais plutot un if en php pour tester la date du jour

    Si on est le premier janvier alors je fais la requête d'update

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Bonjour,
j'ai fait cette condition et testé mais cela ne fonctionne pas mon champ mail reste toujours à 1.
Merci.

 $DateJour 	= date("d/m"); //remettre le champ "mail" à 0 au 1er Janvier de chaque année function set_mail_changed($mail) {     if ($DateJour = '08/02') {         $sql = "UPDATE cdc_personnes SET mail = 0";         $datas = array($mail);         return executeQuery($sql,$datas);     } } 

Reply
réponses:
  • jordane45

    Dans un if il faut 2 =

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Bonjour,
Toujours pareil sans résultat, je n'arrive pas à comprendre pourquoi le champ mail ne passe pas à 0.
Merci.

 $DateJour 	= date("d/m"); //remettre le champ "mail" à 0 au 1er Janvier de chaque année function set_mail_changed($mail) {     if ($DateJour == '09/02') {         $sql = "UPDATE cdc_personnes SET mail = 0";         $datas = array($mail);         return executeQuery($sql,$datas);     } } 

Reply
réponses:
  • jordane45

    Et tu l'appelles où ta fonction ?

  • jordane45

    La fonction ( à placer avec les autres fonctions de ton code)

     function set_mail_changed() {         $sql = "UPDATE cdc_personnes SET mail = 0";         $datas = NULL;         return executeQuery($sql,$datas); } 


    Son appel dans ton script ( à placer au début de ton script.. )
     $DateJour 	= date("d/m");  //remettre le champ "mail" à 0 au 1er Janvier de chaque année de TOUS les mails  if ($DateJour == '09/02') {   set_mail_changed(); } 

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Bonjour,
En fait j'avais oublié d'appeler la fonction. J'ai de nouveau tout testé, tout fonctionne très bien.
Encore tout mes remerciements.
Cordialement.

Reply

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Bonjour, Je mes suis permis de ré ouvrir ce post, car je viens de m'apercevoir que la fonction "set_mail_changed" ne joue pas son rôle, pourtant après un test ça m'avais l'air tout ok, je ne comprends pas ce qui c'est passé.
Je te remercie

 //Met le champ "mail" à 1 function set_mail_envoye($email) {     $sql = "UPDATE cdc_personnes SET mail = 1              WHERE email = ?";             $datas = array($email);       return executeQuery($sql,$datas); }  //Met le champ "mail" à 0 function set_mail_changed() {         $sql = "UPDATE cdc_personnes SET mail = 0";         $datas = NULL;         return executeQuery($sql,$datas); }  //-----------------------------------------------------------------------------// // Début de ton script //-----------------------------------------------------------------------------//      $quant = date("z"); // Quantième du jour dans l'année. NB: le 01/09/AAAAA est le 245è jour de l'année // Si l'on est avant le 01/09, l'année d'adhésion ($aadh) est l'année précédente, sinon c'est l'année courante $aadh =  $quant < 245 ? date("Y")-1 : date("Y");  $DateJour 	= date("d/m"); $mois	    = date('m');   $jour 	    = date('d');  //récupère la liste des anniversaires $anniv = get_Anniv($aadh,$mois,$jour);  //récupère resp $resp = get_configsite_resp();  //si il y a des données à traiter if(!empty($anniv)) {     while ($donnees = $anniv->fetch()) {         $email = $donnees->email;         $prenom = $donnees->prenom;         sendMailAnniv($email,$prenom,$resp); //envoie le mail         set_mail_envoye($email); // met le champ "mail" à 1 une fois le mail envoyé au destinataire     } }  //remettre le champ "mail" à 0 au 1er Janvier de chaque année de TOUS les mails if ($DateJour == '10/02') {   set_mail_changed(); } 

Reply
réponses:
  • jordane45

    1 - Je t'ai indiqué que tu devais faire appel à ce script AVANT le reste
    2 - Peux tu nous montrer ton code COMPLET
    3 - As tu essayé de lancer ce script à la main (sans passer par une cron ) pour voir si il ne t'afficherai pas des messages d'erreur ?

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Bonjour,
Je me suis donné deux jours pour analyser mon problème . En fait j'ai lancé le script à la main le script se lance bien le champ mail passe bien à 0 donc aucune erreur ne s'affiche.
Et lorsque ma tache CRON se lance avec un envoi de mail pour souhaiter un anniversaire le script se lance également donc le champ mail passe à 0, sinon rien ne se passe.
La tache CRON est programmé pour se lancé tous les jours à une heure précise.
Voici ma page complète.
Merci

 <?php //-----------------------------------------------------------------------------// //Activation de l'affichage des erreurs PHP // A placer AU DEBUT de tes scripts... donc AVANT les includes ! //-----------------------------------------------------------------------------//  // Afficher les erreurs à l'écran ini_set('display_errors', 1); // Afficher les erreurs et les avertissements error_reporting(e_all); // Enregistrer les erreurs dans un fichier de log ini_set('log_errors', 1); // Nom du fichier qui enregistre les logs (attention aux droits à l'écriture) ini_set('error_log', dirname(__file__) . '/log_error_php.txt');  //-----------------------------------------------------------------------------// //connexion à la bdd //-----------------------------------------------------------------------------// require_once("init.php");  //-----------------------------------------------------------------------------// //FONCTIONS //-----------------------------------------------------------------------------//  // Fonction qui sert à faire les requêtes SQL // Contient déjà le try/catch function executeQuery($sql,$datas = NULL) {     global $bdd; // permet d'utiliser la variable $bdd dans la fonction     //exécution de la requête     try {         $requete = $bdd->prepare($sql);         $requete->execute($datas);     } catch(Exception $e) {       // en cas d'erreur :         echo " Erreur ! ".$e->getMessage();         echo " Les datas : " ;         print_r($aadh,$mois,$jour);         exit(0); // en cas d'erreur.. arrête le script !     }     return $requete; }  function get_Anniv($aadh,$mois,$jour) {     $sql = "SELECT nom, prenom, dnaiss, email, mail             FROM cdc_personnes P                 LEFT JOIN cdc_adherer A ON P.idpers = A.idpers             WHERE mail = 0             AND annee = ?             AND MONTH(dnaiss) = ?             AND DAY(dnaiss) = ?";     return executeQuery($sql,array($aadh,$mois,$jour)); }  function get_configsite_resp() {     $sql  = "SELECT * FROM cdc_configsite WHERE clef = ? ";     $result =  executeQuery($sql,array('resp'));     $reponse = $result->fetch();     return  !empty($reponse) ? $reponse->valeur : ''; }  function sendMailAnniv($email,$prenom,$resp) {     // Adresse email des destinataires     $destinataire = $email;     // Titre de l'email     $sujet = 'Joyeux Anniversaire';     // Contenu du message de l'email     $message = '<html>';     $message .= '<body><p>Bonjour '.$prenom.'<br/>';     $message .= 'Je te souhaite un bon anniversaire...<br/>';     $message .= 'A bientôt !<br/>';     $message .= ''. $resp . '<br/>';     $message .= '</html>';     // Pour envoyer un email HTML, l'en-tête Content-type doit être défini     $headers = 'MIME-Version: 1.0'."\r\n";     $headers .= 'Content-type: text/html; charset=utf-8'."\r\n";     $headers .= 'From:"cliquedecruet"<[email protected]>'."\n";     // Fonction principale qui envoi l'email     if(!mail($destinataire, $sujet, $message, $headers)) {         echo " Erreur lors de l'envoie du mail !";     } }  //Met le champ "mail" à 1 function set_mail_envoye($email) {     $sql = "UPDATE cdc_personnes SET mail = 1              WHERE email = ?";             $datas = array($email);       return executeQuery($sql,$datas); }  //Met le champ "mail" à 0 function set_mail_changed() {         $sql = "UPDATE cdc_personnes SET mail = 0";         $datas = NULL;         return executeQuery($sql,$datas); }  //-----------------------------------------------------------------------------// // Début de ton script //-----------------------------------------------------------------------------//     $DateJour 	= date("d/m"); //remettre le champ "mail" à 0 au 1er Janvier de chaque année de TOUS les mails if ($DateJour == '12/02') {   set_mail_changed(); }  $quant = date("z"); // Quantième du jour dans l'année. NB: le 01/09/AAAAA est le 245è jour de l'année // Si l'on est avant le 01/09, l'année d'adhésion ($aadh) est l'année précédente, sinon c'est l'année courante $aadh =  $quant < 245 ? date("Y")-1 : date("Y");  $mois	    = date('m');   $jour 	    = date('d');  //récupère la liste des anniversaires $anniv = get_Anniv($aadh,$mois,$jour);  //récupère resp $resp = get_configsite_resp();  //si il y a des données à traiter if(!empty($anniv)) {     while ($donnees = $anniv->fetch()) {         $email = $donnees->email;         $prenom = $donnees->prenom;         sendMailAnniv($email,$prenom,$resp); //envoie le mail         set_mail_envoye($email); // met le champ "mail" à 1 une fois le mail envoyé au destinataire     } } ?>	 

Reply

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Essaye ça ( à la main) et dis nous ce que ça donne

 <?php //-----------------------------------------------------------------------------// //Activation de l'affichage des erreurs PHP // A placer AU DEBUT de tes scripts... donc AVANT les includes ! //-----------------------------------------------------------------------------//  // Afficher les erreurs à l'écran ini_set('display_errors', 1); // Afficher les erreurs et les avertissements error_reporting(E_ALL); // Enregistrer les erreurs dans un fichier de log ini_set('log_errors', 1); // Nom du fichier qui enregistre les logs (attention aux droits à l'écriture) ini_set('error_log', dirname(__file__) . '/log_error_php.txt');  //-----------------------------------------------------------------------------// //connexion à la bdd //-----------------------------------------------------------------------------// require_once("init.php");  //-----------------------------------------------------------------------------// //FONCTIONS //-----------------------------------------------------------------------------//  /** * Fonction pour faire du debug... */ function debug($var,$title=''){ 	echo "<pre><b>".$title."</b><br>"; 	print_r($var); 	echo "</pre>";	 }   // Fonction qui sert à faire les requêtes SQL // Contient déjà le try/catch function executeQuery($sql,$datas = NULL) {     global $bdd; // permet d'utiliser la variable $bdd dans la fonction     //exécution de la requête     try {         $requete = $bdd->prepare($sql);         $requete->execute($datas);     } catch(Exception $e) {       // en cas d'erreur :         echo " Erreur ! ".$e->getMessage();         echo " Les datas : " ;         print_r($aadh,$mois,$jour);         exit(0); // en cas d'erreur.. arrête le script !     }     return $requete; }  function get_Anniv($aadh,$mois,$jour) { 	 	 	     $sql = "SELECT nom, prenom, dnaiss, email, mail             FROM cdc_personnes P                 LEFT JOIN cdc_adherer A ON P.idpers = A.idpers             WHERE mail = 0             AND annee = ?             AND MONTH(dnaiss) = ?             AND DAY(dnaiss) = ?";     $result = executeQuery($sql,array($aadh,$mois,$jour)); 	debug($result,'get_Anniv'); 	return $result; }  function get_configsite_resp() {     $sql  = "SELECT * FROM cdc_configsite WHERE clef = ? ";     $result =  executeQuery($sql,array('resp'));     $reponse = $result->fetch();     $result =  !empty($reponse) ? $reponse->valeur : ''; 	debug($result,'get_configsite_resp'); 	return $result; }  function sendMailAnniv($destinataire,$prenom,$resp) {      // Titre de l'email     $sujet = 'Joyeux Anniversaire';     // Contenu du message de l'email     $message = '<html>';     $message .= '<body><p>Bonjour '.$prenom.'<br/>';     $message .= 'Je te souhaite un bon anniversaire...<br/>';     $message .= 'A bientôt !<br/>';     $message .= ''. $resp . '<br/>';     $message .= '</html>';     // Pour envoyer un email HTML, l'en-tête Content-type doit être défini     $headers = 'MIME-Version: 1.0'."\r\n";     $headers .= 'Content-type: text/html; charset=utf-8'."\r\n";     $headers .= 'From:"cliquedecruet"<[email protected]>'."\n";     // Fonction principale qui envoi l'email     if(!mail($destinataire, $sujet, $message, $headers)) {         echo " Erreur lors de l'envoie du mail !";     }else{ 		debug(" Mail envoyé à : " . $destinataire,'sendMailAnniv'); 	} }  //Met le champ "mail" à 1 function set_mail_envoye($email) {     $sql = "UPDATE cdc_personnes SET mail = 1              WHERE email = ?";             $datas = array($email);       $result = executeQuery($sql,$datas); 	debug($result,'set_mail_envoye'); 	return $result; }  //Met le champ "mail" à 0 function set_mail_changed() { 	$sql = "UPDATE cdc_personnes SET mail = 0"; 	$datas = NULL; 	$result = executeQuery($sql,$datas); 	debug($result,'set_mail_changed'); 	return $result; }  //-----------------------------------------------------------------------------// // Début de ton script //-----------------------------------------------------------------------------//     $DateJour 	= date("d/m"); //remettre le champ "mail" à 0 au 1er Janvier de chaque année de TOUS les mails if ($DateJour == '12/02') {   echo " Réinitialisation des champs MAIL ...";   set_mail_changed(); } else { 	echo "Pas besoin de réinitialiser les champs mail .." }  $quant = date("z"); // Quantième du jour dans l'année. NB: le 01/09/AAAAA est le 245è jour de l'année // Si l'on est avant le 01/09, l'année d'adhésion ($aadh) est l'année précédente, sinon c'est l'année courante $aadh =  $quant < 245 ? date("Y")-1 : date("Y");  $mois	    = date('m');   $jour 	    = date('d');  //récupère la liste des anniversaires $anniv = get_Anniv($aadh,$mois,$jour);  //récupère resp $resp = get_configsite_resp();  //si il y a des données à traiter if(!empty($anniv)) {     while ($donnees = $anniv->fetch()) {         $email = $donnees->email;         $prenom = $donnees->prenom;         sendMailAnniv($email,$prenom,$resp); //envoie le mail         set_mail_envoye($email); // met le champ "mail" à 1 une fois le mail envoyé au destinataire     } }else{ 	echo " Aucune donnée à traiter ce jour.... "; } ?>	 

Reply

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Il n'y a aucune erreur qui est retournée...absolument rien.

Reply
réponses:
  • jordane45

    pas d'erreur....... ok ......
    mais heu... y'a bien des choses qui s'affichent non ??!!

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

malheureusement non rien, je te joint une capture avec l'URL pour te montrer.
https://www.cjoint.com/c/HBmnfOXBpiL

Reply
réponses:
  • jordane45

    ton fichier est bien encodé en UTF8 sans bom ?

    Tu es en local ou sur un serveur ?

    Quelle est l'url que tu tapes pour le lancer manuellement ?

    Peux tu tester ça :

     <?php error_reporting(E_ALL); ini_set('display_errors', TRUE); ini_set('display_startup_errors', TRUE);  // Enregistrer les erreurs dans un fichier de log ini_set('log_errors', 1); // Nom du fichier qui enregistre les logs (attention aux droits à l'écriture) ini_set('error_log', dirname(__file__) . '/log_error_php.txt');  //-----------------------------------------------------------------------------// //connexion à la bdd //-----------------------------------------------------------------------------// require_once("init.php");  //-----------------------------------------------------------------------------// //FONCTIONS //-----------------------------------------------------------------------------//  /** * Fonction pour faire du xdebug... */ function xdebug($var,$title=''){  echo "<pre><b>".$title."</b><br>";  print_r($var);  echo "</pre>";  }   // Fonction qui sert à faire les requêtes SQL // Contient déjà le try/catch function executeQuery($sql,$datas = NULL) {     global $bdd; // permet d'utiliser la variable $bdd dans la fonction     //exécution de la requête     try {         $requete = $bdd->prepare($sql);         $requete->execute($datas);     } catch(Exception $e) {       // en cas d'erreur :         echo " Erreur ! ".$e->getMessage();         echo " Les datas : " ;         print_r($aadh,$mois,$jour);         exit(0); // en cas d'erreur.. arrête le script !     }     return $requete; }  function get_Anniv($aadh,$mois,$jour) {     $sql = "SELECT nom, prenom, dnaiss, email, mail             FROM cdc_personnes P                 LEFT JOIN cdc_adherer A ON P.idpers = A.idpers             WHERE mail = 0             AND annee = ?             AND MONTH(dnaiss) = ?             AND DAY(dnaiss) = ?";     $result = executeQuery($sql,array($aadh,$mois,$jour));  xdebug($result,'get_Anniv');  return $result; }  function get_configsite_resp() {     $sql  = "SELECT * FROM cdc_configsite WHERE clef = ? ";     $result =  executeQuery($sql,array('resp'));     $reponse = $result->fetch();     $result =  !empty($reponse) ? $reponse->valeur : '';  xdebug($result,'get_configsite_resp');  return $result; }  function sendMailAnniv($destinataire,$prenom,$resp) {      // Titre de l'email     $sujet = 'Joyeux Anniversaire';     // Contenu du message de l'email     $message = '<html>';     $message .= '<body><p>Bonjour '.$prenom.'<br/>';     $message .= 'Je te souhaite un bon anniversaire...<br/>';     $message .= 'A bientôt !<br/>';     $message .= ''. $resp . '<br/>';     $message .= '</html>';     // Pour envoyer un email HTML, l'en-tête Content-type doit être défini     $headers = 'MIME-Version: 1.0'."\r\n";     $headers .= 'Content-type: text/html; charset=utf-8'."\r\n";     $headers .= 'From:"cliquedecruet"<[email protected]>'."\n";     // Fonction principale qui envoi l'email     if(!mail($destinataire, $sujet, $message, $headers)) {         echo " Erreur lors de l'envoie du mail !";     }else{   xdebug(" Mail envoyé à : " . $destinataire,'sendMailAnniv');  } }  //Met le champ "mail" à 1 function set_mail_envoye($email) {     $sql = "UPDATE cdc_personnes SET mail = 1              WHERE email = ?";             $datas = array($email);       $result = executeQuery($sql,$datas);  xdebug($result,'set_mail_envoye');  return $result; }  //Met le champ "mail" à 0 function set_mail_changed() {  $sql = "UPDATE cdc_personnes SET mail = 0";  $datas = NULL;  $result = executeQuery($sql,$datas);  xdebug($result,'set_mail_changed');  return $result; }  //-----------------------------------------------------------------------------// // Début de ton script //-----------------------------------------------------------------------------//    echo "<br> DEBUT DU SCRIPT -------- >> " . date('Y-m-d H:i:s') . '<br>';    $DateJour  = date("d/m"); //remettre le champ "mail" à 0 au 1er Janvier de chaque année de TOUS les mails if ($DateJour == '12/02') {   echo " Réinitialisation des champs MAIL ...";   set_mail_changed(); } else {  echo "Pas besoin de réinitialiser les champs mail .."; }  $quant = date("z"); // Quantième du jour dans l'année. NB: le 01/09/AAAAA est le 245è jour de l'année // Si l'on est avant le 01/09, l'année d'adhésion ($aadh) est l'année précédente, sinon c'est l'année courante $aadh =  $quant < 245 ? date("Y")-1 : date("Y");  $mois     = date('m');   $jour      = date('d');  //récupère la liste des anniversaires $anniv = get_Anniv($aadh,$mois,$jour);  //récupère resp $resp = get_configsite_resp();  //si il y a des données à traiter if(!empty($anniv)) {     while ($donnees = $anniv->fetch()) {         $email = $donnees->email;         $prenom = $donnees->prenom;         sendMailAnniv($email,$prenom,$resp); //envoie le mail         set_mail_envoye($email); // met le champ "mail" à 1 une fois le mail envoyé au destinataire     } }else{  echo " Aucune donnée à traiter ce jour.... "; } ?>  

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

-oui l'encodage est bien en utf8 sans bom
-je suis sur mon serveur
-url pour lancer le script est www.cliquedecruet.fr/libs/envoi_anniv.php

toujours pareil avec ton nouveau test...

Reply

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

là je viens de refaire un test juste pour une info...
J'ai remis le champ mail à 1 j'ai ensuite lancé l'url www.cliquedecruet.fr/libs/envoi_anniv.php et le champ mail est passé à 0 avec ton script initial.

Reply

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

oui je ne sais pas là je viens de réessayer et voilà le résultat..

 DEBUT DU SCRIPT -------- >> 2018-02-12 17:47:50 Réinitialisation des champs MAIL ...  set_mail_changed PDOStatement Object (     [queryString] => UPDATE cdc_personnes SET mail = 0 )  get_Anniv PDOStatement Object (     [queryString] => SELECT nom, prenom, dnaiss, email, mail             FROM cdc_personnes P                 LEFT JOIN cdc_adherer A ON P.idpers = A.idpers             WHERE mail = 0             AND annee = ?             AND MONTH(dnaiss) = ?             AND DAY(dnaiss) = ? )  get_configsite_resp Mon nom et Prénom 

Reply
réponses:
  • jordane45

    ben donc c'est bon non ?

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Là je viens de mettre la $dateJour au 13/02 j'ai basculé le tout sur mon serveur et j'ai mis dans PhpMyadmin manuellement mon champ mail à 1 donc à priori demain ce champ devrais passer à 0. Je te redis demain.
Merci.
Bonne soirée.

Reply

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Bonjour,
Hélas ce matin le champ mail est resté à 1...
Par contre je viens de déclencher le script manuellement et ce champ est passé à 0.
Ne faudrait-il pas peut-être créé une tache CRON pour déclencher le script en créant une nouvelle page car il y a déjà la tache CRON pour l'envoi de mail pour les anniversaires, c'est juste une suggestion.
Merci

 <?php error_reporting(E_ALL); ini_set('display_errors', TRUE); ini_set('display_startup_errors', TRUE);  // Enregistrer les erreurs dans un fichier de log ini_set('log_errors', 1); // Nom du fichier qui enregistre les logs (attention aux droits à l'écriture) ini_set('error_log', dirname(__file__) . '/log_error_php.txt');  //-----------------------------------------------------------------------------// //connexion à la bdd //-----------------------------------------------------------------------------// require_once("init.php");  //-----------------------------------------------------------------------------// //FONCTIONS //-----------------------------------------------------------------------------//  // Fonction qui sert à faire les requêtes SQL // Contient déjà le try/catch function executeQuery($sql,$datas = NULL) {     global $bdd; // permet d'utiliser la variable $bdd dans la fonction     //exécution de la requête     try {         $requete = $bdd->prepare($sql);         $requete->execute($datas);     } catch(Exception $e) {       // en cas d'erreur :         echo " Erreur ! ".$e->getMessage();         echo " Les datas : " ;         print_r($aadh,$mois,$jour);         exit(0); // en cas d'erreur.. arrête le script !     }     return $requete; }  function get_Anniv($aadh,$mois,$jour) {     $sql = "SELECT nom, prenom, dnaiss, email, mail             FROM cdc_personnes P                 LEFT JOIN cdc_adherer A ON P.idpers = A.idpers             WHERE mail = 0             AND annee = ?             AND MONTH(dnaiss) = ?             AND DAY(dnaiss) = ?";     return executeQuery($sql,array($aadh,$mois,$jour)); }  function get_configsite_resp() {     $sql  = "SELECT * FROM cdc_configsite WHERE clef = ? ";     $result =  executeQuery($sql,array('resp'));     $reponse = $result->fetch();     return  !empty($reponse) ? $reponse->valeur : ''; }  function sendMailAnniv($email,$prenom,$resp) {     // Adresse email des destinataires     $destinataire = $email;     // Titre de l'email     $sujet = 'Joyeux Anniversaire';     // Contenu du message de l'email     $message = '<html>';     $message .= '<body><p>Bonjour '.$prenom.'<br/>';     $message .= 'Je te souhaite un bon anniversaire...<br/>';     $message .= 'A bientôt !<br/>';     $message .= ''. $resp . '<br/>';     $message .= '</html>';     // Pour envoyer un email HTML, l'en-tête Content-type doit être défini     $headers = 'MIME-Version: 1.0'."\r\n";     $headers .= 'Content-type: text/html; charset=utf-8'."\r\n";     $headers .= 'From:"cliquedecruet"<[email protected]>'."\n";     // Fonction principale qui envoi l'email     if(!mail($destinataire, $sujet, $message, $headers)) {         echo " Erreur lors de l'envoie du mail !";     } }  //Met le champ "mail" à 1 function set_mail_envoye($email) {     $sql = "UPDATE cdc_personnes SET mail = 1              WHERE email = ?";             $datas = array($email);       return executeQuery($sql,$datas); }  //Met le champ "mail" à 0 function set_mail_changed() {         $sql = "UPDATE cdc_personnes SET mail = 0";         $datas = NULL;         return executeQuery($sql,$datas); }  //-----------------------------------------------------------------------------// // Début de ton script //-----------------------------------------------------------------------------//     $DateJour 	= date("d/m"); //remettre le champ "mail" à 0 au 1er Janvier de chaque année de TOUS les mails if ($DateJour == '13/02') {   set_mail_changed(); }  $quant = date("z"); // Quantième du jour dans l'année. NB: le 01/09/AAAAA est le 245è jour de l'année // Si l'on est avant le 01/09, l'année d'adhésion ($aadh) est l'année précédente, sinon c'est l'année courante $aadh =  $quant < 245 ? date("Y")-1 : date("Y");  $mois	    = date('m');   $jour 	    = date('d');  //récupère la liste des anniversaires $anniv = get_Anniv($aadh,$mois,$jour);  //récupère resp $resp = get_configsite_resp();  //si il y a des données à traiter if(!empty($anniv)) {     while ($donnees = $anniv->fetch()) {         $email = $donnees->email;         $prenom = $donnees->prenom;         sendMailAnniv($email,$prenom,$resp); //envoie le mail         set_mail_envoye($email); // met le champ "mail" à 1 une fois le mail envoyé au destinataire     } } ?>	  

Reply
réponses:
  • jordane45


    Ne faudrait-il pas peut-être créé une tache CRON pour déclencher le script en créant une nouvelle page

    C'est ce que je t'avais conseillé au départ ....
    Un script... qui se lance à la date voulue et qui ne sert qu'à ça !


    Par contre... vu comment c'est fait maintenant... rien ne t'empèche de le laisser comme ça.

    car il y a déjà la tache CRON pour l'envoi de mail pour les anniversaires,

    Mais nous sommes bien d'accord qu'actuellement tu as :
    - Un seul script PHP (celui qu'on est en train de modifier)
    - Une seule tâche planifiée ... qui lance CE script (et pas un autre).

    Je sens venir la réponse du genre : ben non;.. j'ai deux tâches planifiées .....

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Oui j'ai bien qu'une et une seule tache planifié avec uniquement un seul script....

Reply

Marsh

NOVEMBER 9, 2013 AT 9:15 PM

Alors actuellement j'ai une tache CRON tache planifié à 3h chaque jour qui lance le script du fichier envoi_anniv.php (anniversaire des membres et change la valeur du champ mail)
Je peux recréé une tache CRON qui lancera le fichier change_mail.php le 01/01 à 0h (qui remets la valeur initial du champ mail à 0)
Par contre pourquoi tu as dit...
Par contre... vu comment c'est fait maintenant... rien ne t'empèche de le laisser comme ça.

Sinon dans le nouveau fichier je mets uniquement les deux fonctions en fait?
Tu peux me dire ce que tu penses de ça?
Je te remercie.

 <?php error_reporting(E_ALL); ini_set('display_errors', TRUE); ini_set('display_startup_errors', TRUE);  // Enregistrer les erreurs dans un fichier de log ini_set('log_errors', 1); // Nom du fichier qui enregistre les logs (attention aux droits à l'écriture) ini_set('error_log', dirname(__file__) . '/log_error_php.txt');  //-----------------------------------------------------------------------------// //connexion à la bdd //-----------------------------------------------------------------------------// require_once("init.php");  //-----------------------------------------------------------------------------// //FONCTIONS //-----------------------------------------------------------------------------//  // Fonction qui sert à faire les requêtes SQL // Contient déjà le try/catch function executeQuery($sql,$datas = NULL) {     global $bdd; // permet d'utiliser la variable $bdd dans la fonction     //exécution de la requête     try {         $requete = $bdd->prepare($sql);         $requete->execute($datas);     } catch(Exception $e) {       // en cas d'erreur :         echo " Erreur ! ".$e->getMessage();         exit(0); // en cas d'erreur.. arrête le script !     }     return $requete; }  //Met le champ "mail" à 0 function set_mail_changed() {         $sql = "UPDATE cdc_personnes SET mail = 0";         $datas = NULL;         return executeQuery($sql,$datas); }  //-----------------------------------------------------------------------------// // Début de ton script //-----------------------------------------------------------------------------//     $DateJour 	= date("d/m"); //remettre le champ "mail" à 0 au 1er Janvier de chaque année de TOUS les mails if ($DateJour == '01/01') {   set_mail_changed(); } ?>	 

Reply

Leave a Replay

Make sure you enter the(*)required information where indicate.HTML code is not allowed