当表更新时从 MySQL 触发器发送电子邮件

2022-01-01 00:00:00 email sql sendmail mysql triggers

考虑一个表为table2,我喜欢在这个表上添加一个trigger update as

Consider a table as table2, i like to add a trigger on this table update as

select Num into num from table1 where ID=new.id;
BEGIN
DECLARE done int default false;
DECLARE cur1 CURSOR FOR select EmailId from users where Num=num;
DECLARE continue handler for not found set done = true;
OPEN cur1;
my_loop: loop
    fetch cur1 into email_id;
    if done then
        leave my_loop;
    end if;
    //send mail to all email id.
end loop my_loop;
close cur1;
END;

评论的地方有什么简单的写法吗?向从表 users 中检索到的所有电子邮件 ID 发送电子邮件.

Is there any simple method to write in the place commented? To send a email to all the email id retrieved from table users.

我在 XAMPP(phpmyadmin) 中使用 MySQL.

I am using MySQL in XAMPP(phpmyadmin).

推荐答案

我反对那个解决方案.将发送电子邮件的负载放在数据库服务器上可能会很糟糕.

I'm against that solution. Putting the load of sending e-mails in your Database Server could end very bad.

在我看来,您应该做的是创建一个表格,将您想要发送的电子邮件排队,并有一个流程来检查是否有要发送的电子邮件,如果是肯定的,则将其发送.

In my opinion, what you should do is create a table that queues the emails you would want to send and have a process that checks if there are emails to be sent and send them if positive.

相关文章