发送生日电子邮件

上次更新: 2023-08-17
  • 主题:
  • Workflows
    查看有关此主题的更多信息

此用例介绍了如何计划在收件人生日当天向其列表发送定期电子邮件。

为了设置此用例,我们创建了以下定位工作流:

此(每日运行)工作流会选择其生日为当前日期的所有收件人。

为此,请创建一个营销活动并添加 活动工作流.

然后按照下面详述的步骤操作。

识别其生日为的收件人

配置之后 Scheduler 活动以便工作流每天开始一次,识别其出生日期等于当前日期的所有收件人。

要执行此操作,请应用以下步骤:

  1. 拖放 Query 活动并将其双击到工作流中。

  2. 单击 编辑查询 链接并选择 Filtering conditions.

  3. 单击 Expression 列并单击 Edit expression 以打开表达式编辑器。

  4. 单击 Advanced selection 以选择过滤模式。

  5. 选择 Edit the formula using an expression 并单击 Next 以显示表达式编辑器。

  6. 在函数列表中,双击 Day,可通过访问 Date 节点。 此函数返回数字,该数字表示与作为参数传递的日期对应的日期。

  7. 在可用字段列表中,双击 Birth date. 然后,该编辑器的上半部分会显示以下公式:

    Day(@birthDate)
    

    单击 Finish 确认。

  8. 在查询编辑器的第一个单元格中, Operator 列,选择 equal to.

  9. 接下来,单击第二列的第一个单元格(Value),然后单击 Edit expression 以打开表达式编辑器。

  10. 在函数列表中,双击 Day,可通过访问 Date 节点。

  11. 双击 GetDate 函数以检索当前日期。

    该编辑器的上半部分显示以下公式:

    Day(GetDate())
    

    单击 Finish 确认。

  12. 重复此过程以检索对应于当前月份的出生月份。 要执行此操作,请单击 Add 按钮并重复步骤3至10,更换 Day 替换为 Month.

    完整的查询如下所示:

链接结果 Query 活动到 Email delivery 活动,在收件人的生日当天向所有收件人的列表发送电子邮件。

包括2月29日出生的收件人(可选)

如果您希望包含所有在2月29日出生的收件人,则此用例将介绍如何计划向生日收件人的列表发送定期电子邮件 — 无论是否为闰年。

此用例的主要实施步骤包括:

  • 选择收件人
  • 选择是否为闰年
  • 选择2月29日出生的任何收件人

为了设置此用例,我们创建了以下定位工作流:

如果当前年份 不是闰年 并且工作流在3月1日运行,我们需要选择昨天生日(2月29日)的所有收件人,并将他们添加到收件人列表。 在任何其他情况下,均无需执行其他操作。

步骤1:选择收件人

配置之后 Scheduler 活动以便工作流每天启动,识别其周年纪念日为当天的所有收件人。

注意

如果当前年份是闰年,则所有在2月29日出生的收件人都会自动包含在内。

选择其生日对应于当前日期的收件人,将显示在 识别其生日为的收件人 部分。

步骤2:选择是否为闰年

Test 活动允许您检查是否为闰年,以及当前日期是否为3月1日。

如果测试得到验证(该年不是闰年 — 没有2月29日 — 并且当前日期确实是3月1日), True 已启用过渡,并将在2月29日出生的收件人添加到3月1日的投放中。 否则, False 已启用过渡,只有生于当前日期的收件人才会收到投放。

将下面的代码复制并粘贴到 Initialization script 的部分 Advanced 选项卡。

function isLeapYear(iYear)
{
    if(iYear/4 == Math.floor(iYear/4))
    {
        if(iYear/100 != Math.floor(iYear/100))
        {
            // Divisible by 4 only -> Leap Year
            return 1;
        }
        else
        {
            if(iYear/400 == Math.floor(iYear/400))
            {
                // Divisible by 4, 100 and 400 -> Leap year
                return 1;
            }
        }
    }
    // all others: no leap year
    return 0;
}

// Return today's date and time
var currentTime = new Date()
// returns the month (from 0 to 11)
var month = currentTime.getMonth() + 1
// returns the day of the month (from 1 to 31)
var day = currentTime.getDate()
// returns the year (four digits)
var year = currentTime.getFullYear()

// is current year a leap year?
vars.currentIsALeapYear = isLeapYear(year);

// is current date the first of march?
if(month == 3 && day == 1) {
  // today is 1st of march
vars.firstOfMarch = 1;
}

将以下条件添加到 Conditional forks 部分:

vars.currentIsALeapYear == 0 && vars.firstOfMarch == 1

步骤3:选择2月29日出生的任何收件人

创建 Fork 活动,并将其中一个叫客过渡链接到 Query 活动。

在此查询中,选择出生日期为2月29日的所有收件人。

将结果与 Union 活动。

链接二者的结果 Test 活动分支到 Email delivery 活动,向生日当天的所有收件人列表发送电子邮件,甚至向2月29日出生的非闰年收件人发送电子邮件。

创建循环投放

添加 循环投放 活动基于要发送的生日电子邮件模板。

注意

对于要执行的工作流,必须启动与Campaign包相关的技术工作流。 有关详细信息,请参见 技术工作流列表 部分。

如果为营销活动启用了批准步骤,则仅在确认了这些步骤后才会发送投放。 有关更多信息,请参阅一节。

在此页面上