来自MySQL查询的动态邮件列表

时间:2018-10-18 14:36:12

标签: php mysql bash woocommerce phpmailer

我最近在我的Wordpress(woocommerce)网站上实现了“奖励积分”系统。

我构建了一个MySQL查询,以向我显示每个客户的姓名,电子邮件地址和当前积分余额:

SELECT  
            b1.meta_value AS first_name, 
            b2.meta_value as last_name, 
            b3.meta_value as points_balance,
            a.user_email,
            p.points_balance

FROM    wp_zaydb6_users a
                INNER JOIN wp_usermeta b1 ON b1.user_id = a.ID AND b1.meta_key = 'first_name' 
                INNER JOIN wp_usermeta b2 ON b2.user_id = a.ID AND b2.meta_key = 'last_name'
                INNER JOIN wp_usermeta b3 ON b3.user_id = a.ID AND b3.meta_key = 'wc_points_balance'

WHERE  b3.meta_value > 0

这将返回如下内容:

John    Smith   511 j.smith@gmail.com
Michael Barrymore   71  MICHAEL@BARRYMORE.COM.AU
Bob Monkhouse   326 Bob.monkhouse@bobmonk.at
Jane    Doe 176 Jane.Doe@janedoe.ch
Ricky   Martin  511 r.martin@gmail.com

我的下一步是构建一个脚本(bash,最好是PHP),该脚本将遍历每个记录,提取每个“ First_name”,打印points_balance并将其通过电子邮件发送给相关用户。所有这些都需要用HTML格式的电子邮件包装,而不是纯文本。

我还没有构建动态邮件列表,所以这对我来说是新的。

最好的前进方向是什么?

1 个答案:

答案 0 :(得分:1)

我有一个旧系统,它必须执行这样的操作,并且我以非常快速但又很笨拙的方式进行操作。

$row_message = fetch_html_template('renew_error'); //returns the html template text, that has special markings like [name], [username].
$row_message['text'] = str_replace('[name]', $variableThatHasUsersName, $row_message['text']);

它是一种非常肮脏且快速的修复方法。如果要删除它,则可以对任意多个变量使用str_replace多次。

P.S。如果这对您有帮助,请接受答案。