我最近在我的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格式的电子邮件包装,而不是纯文本。
我还没有构建动态邮件列表,所以这对我来说是新的。
最好的前进方向是什么?
答案 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。如果这对您有帮助,请接受答案。