J'essaye d'envoyer une mise à jour d'email aux utilisateurs du candidates_table
mais le contenu de l'email vient de la table jobs_list
. S'il vous plaît voir ma tentative ci-dessous, j'utilise PHPmailer et je ne reçois aucune erreur. Le script ci-dessous est le script de gestion d'un formulaire.Comment envoyer un email basé sur deux tables après une requête d'insertion?
Les données du jobs_list
sont affichées, mais les données candidates_table
ne le sont pas.
Ceci est juste en dessous de la déclaration d'insertion:
MISE À JOUR:
$vac_last_id = $dbh->lastInsertId();
echo $vac_last_id;
$sql = $dbh->prepare("SELECT * FROM jobs_list WHERE id=:id");
$sql->bindValue(':id', $vac_last_id, PDO::PARAM_INT);
if($sql->execute()) {
$sql->setFetchMode(PDO::FETCH_ASSOC);
}
while($row = $sql->fetch()) {
$mail = new PHPMailer;
$mail->isSMTP();
$mail->Host = '';
$mail->SMTPAuth = true;
$mail->SMTPKeepAlive = true; // SMTP connection will not close after each email sent, reduces SMTP overhead
$mail->Port =;
$mail->Username = '';
$mail->Password = '';
$mail->setFrom('', '- Vacancies');
$mail->addReplyTo('', '- Vacancies');
$mail->Subject = "";
//Same body for all messages, so set this before the sending loop
//If you generate a different body for each recipient (e.g. you're using a templating system),
//set it inside the loop
$mail->Body = 'THE BODY...';
//msgHTML also sets AltBody, but if you want a custom one, set it afterwards
$mail->AltBody = 'To view the message, please use an HTML compatible email viewer';
//Connect to the database and select the recipients from your mailing list that have not yet been sent to
//You'll need to alter this to match your database
$mysql = $dbh->prepare("SELECT * FROM candidates_table WHERE receive_email = 2");
if ($mysql->execute()) {
$mysql->setFetchMode(PDO::FETCH_ASSOC);
}
foreach ($mysql as $row) { //This iterator syntax only works in PHP 5.4+
$mail->addAddress($row['email_address'], $row['full_name']);
if (!$mail->send()) {
echo "Mailer Error (" . str_replace("@", "@", $row["email_address"]) . ') ' . $mail->ErrorInfo . '<br />';
break; //Abandon sending
} else {
echo "Message sent to :" . $row['full_name'] . ' (' . str_replace("@", "@", $row['email_address']) . ')<br />';
//Mark it as sent in the DB
}
// Clear all addresses and attachments for next loop
$mail->clearAddresses();
}
}
* * CLAUSE OÙ: Qu'est-ce '..jobs_list où id..' dans' $ sql = $ dbh-> prepare ("SELECT * FROM jobs_list où id ORDER BY id 0 DESC LIMIT, 1") "? –
Cela vient de sélectionner le dernier identifiant inséré dans la table 'jobs_list'. pour le contenu de l'email. – bob
Comment il va sélectionner? 'WHERE id' n'est pas correct. Vous n'avez attribué aucune valeur à 'id'. –