使用聚合 using-aggregates

此用例详细说明了如何自动识别添加到数据库中的最后一个收件人。

按照以下流程,将数据库中的收件人创建日期与上次已知使用聚合创建收件人的日期进行比较。 此外,还将选择在同一天创建的所有收件人。

执行 创建日期=最大日期(创建日期) 对收件人键入过滤器,您必须运行工作流以执行以下步骤:

  1. 使用基本查询检索数据库收件人。 有关此步骤的更多信息,请参阅 创建查询.
  2. 使用从生成的结果计算上次创建收件人的已知日期 最大值(创建日期) 聚合函数。
  3. 将每个收件人链接到聚合函数会生成相同的模式。
  4. 通过编辑后的架构使用聚合筛选收件人。

步骤1:计算聚合结果 step-1--calculating-the-aggregate-result

  1. 创建查询。 在本例中,目标是计算数据库中所有收件人的上次已知创建日期。 因此,查询不包含过滤器。

  2. 选择 Add data

  3. 在打开的窗口中,选择 Data linked to the filtering dimensionFiltering dimension data.

  4. Data to add 窗口,添加一列以计算 创建日期 收件人表中的字段。 您可以使用表达式编辑器或 max(@created) 直接插入中的字段 Expression 列。 然后单击 Finish 按钮。

  5. 单击 Edit additional dataAdvanced parameters…. 勾选 Disable automatic adding of the primary keys of the targeting dimension 选项。

    此选项确保不会显示所有收件人,并且不会保留明确添加的数据。 在这种情况下,该日期是指上次创建收件人的日期。

    保持选中 Remove duplicate rows (DISTINCT) 选项。

步骤2:关联收件人和聚合函数结果 step-2--linking-the-recipients-and-the-aggregation-function-result

要将处理收件人的查询链接到执行聚合函数计算的查询,必须使用模式编辑活动。

  1. 将收件人的查询定义为主集。

  2. Links 选项卡,添加新链接,并在打开的窗口中输入信息,如下所示:

    • 选择与聚合相关的临时架构。 此架构的数据将添加到主集的成员中。
    • 选择 Use a simple join 将聚合结果链接到主集的每个收件人。
    • 最后,指定链接是 Type 11 simple link.

因此,聚合结果链接到每个收件人。

步骤3:使用聚合过滤收件人。 step-3--filtering-recipients-using-the-aggregate-

建立链接后,聚合结果和收件人构成同一临时模式的一部分。 因此,可以在架构上创建过滤器,以比较收件人的创建日期与最后已知创建日期,该日期由聚合函数表示。 此过滤器使用拆分活动执行。

  1. General 选项卡,选择 收件人 作为定位维度和 编辑架构 作为过滤维度(在集客过渡模式活动上进行过滤)。

  2. subsets 选项卡,选择 Add a filtering condition on the inbound population 然后单击 Edit….

  3. 使用表达式编辑器,在收件人的创建日期与聚合计算的创建日期之间添加相等条件。

    数据库中的日期类型字段通常以毫秒为单位保存。 因此,您必须将这些时间延长一整天,以避免检索仅创建该毫秒的收件人。

    要执行此操作,请使用 ToDate 函数,可在表达式编辑器中使用,它可将日期和小时转换为简单日期。

    因此,用于标准的表达式为:

    • ExpressiontoDate([target/@created]).
    • ValuetoDate([datemax/expr####]),其中expr####与聚合函数查询中指定的聚合相关。

因此,拆分活动的结果与上次已知创建日期同一天创建的收件人相关。

然后,您可以添加其他活动(如列表更新或投放)以丰富您的工作流。

recommendation-more-help
601d79c3-e613-4db3-889a-ae959cd9e3e1