收藏集管理函数 collection-management-functions

表达式语言还引入了一组查询集合的函数。

这些职能说明如下。 在以下示例中,我们使用包含集合的事件有效负载:

                {
   "_experience":{
      "campaign":{
         "message":{
            "profile":{
               "pushNotificationTokens":[
                  {
                     "token":"token_1",
                     "application":{
                        "_id":"APP1",
                        "name":"MarltonMobileApp",
                        "version":"1.0"
                     }
                  },
                  {
                     "token":"token_2",
                     "application":{
                        "_id":"APP2",
                        "name":"MarketplaceApp",
                        "version":"1.0"
                     }
                  },
                  {
                     "token":"token_3",
                     "application":{
                        "_id":"APP3",
                        "name":"VendorApp",
                        "version":"2.0"
                     }
                  }
               ]
            }
         }
      }
   },
   "timestamp":"1536160728"
}

函数“all(<condition>)”

all 函数通过使用布尔表达式来定义给定集合上的过滤器。

<listExpression>.all(<condition>)

例如,在所有应用程序用户中,您可以使用IOS 13(布尔表达式“IOS 13==使用的应用程序”)获取这些用户。 此函数的结果是包含与布尔表达式匹配项目的过滤列表(例如:应用程序用户1、应用程序用户34、应用程序用户432)。

在数据源条件活动中,您可以检查 all 函数是否为null。 您也可以合并此 all 函数和其他函数,例如 count. 有关更多信息,请参阅 数据源条件活动.

示例 1:

我们要检查用户是否已安装了应用程序的特定版本。 为此,我们将获得与版本为1.0的移动应用程序关联的所有推送通知令牌。然后,我们使用 count 函数,以检查返回的令牌列表是否至少包含一个元素。

count(@{LobbyBeacon._experience.campaign.message.profile.pushNotificationTokens.all(currentEventField.application.version == "1.0").token}) > 0

结果为true。

示例 2:

在这里,我们使用 count 函数检查集合中是否存在推送通知令牌。

count(@{LobbyBeacon._experience.campaign.message.profile.pushNotificationTokens.all().token}) > 0

结果将会是真。

NOTE
当过滤条件在 all() 函数为空,则过滤器将返回列表中的所有元素。 但是,要计算集合的元素数,不需要all函数。
count(@{LobbyBeacon._experience.campaign.message.profile.pushNotificationTokens.token})

表达式的结果为 3.

示例 3:

在此处,我们检查个人在过去24小时内是否未收到任何通信。 我们使用基于集合的两个元素的两个表达式,过滤从ExperiencePlatform数据源检索到的体验事件集合。 特别是,会将事件的时间戳与返回的日期时间进行比较 nowWithDelta 函数。

count(#{ExperiencePlatform.MarltonExperience.experienceevent.all(
   currentDataPackField.directMarketing.sends.value > 0 and
   currentDataPackField.timestamp > nowWithDelta(-1, "days")).timestamp}) == 0

如果没有体验事件符合这两个条件,则结果将为true。

示例 4:

在此处,我们要检查个人在过去7天内是否至少启动过一次应用程序,以便触发推送通知,邀请他们启动教程。

count(
 #{ExperiencePlatform.AnalyticsData.experienceevent.all(
 nowWithDelta(-7,"days") <= currentDataPackField.timestamp
 and currentDataPackField.application.firstLaunches.value > 0
)._id}) > 0
NOTE
currentEventField 仅在处理事件集合和 currentDataPackField
处理数据源集合时。 处理收藏集时 allfirstlast, we
逐个循环集合的每个元素。 currentEventFieldcurrentDataPackField
对应于正在循环的元素。

函数“first(<condition>)”和“last(<condition>)”

firstlast 函数还支持对集合定义过滤器,同时返回满足过滤器的列表的第一个/最后一个元素。

<listExpression>.first(<condition>)

<listExpression>.last(<condition>)

示例 1:

此表达式返回与版本为1.0的移动应用程序关联的第一个推送通知令牌。

@{LobbyBeacon._experience.campaign.message.profile.pushNotificationTokens.first(currentEventField.application.version == "1.0").token

结果为“token_1”。

示例 2:

此表达式返回与版本为1.0的移动应用程序关联的最后一个推送通知令牌。

@{LobbyBeacon._experience.campaign.message.profile.pushNotificationTokens.last&#8203;(currentEventField.application.version == "1.0").token}

结果为“token_2”。

NOTE
体验事件将作为集合,以反向时间顺序从Adobe Experience Platform中进行检索,因此:
  • first 函数将返回最近的事件
  • last 函数将返回最早的一个。

示例 3:

我们检查第一个(最新)DMA ID为非零值的Adobe Analytics事件是否具有等于602的值。

#{ExperiencePlatform.AnalyticsProd_EvarsProps.experienceevent.first(
currentDataPackField.placeContext.geo.dmaID > 0).placeContext.geo.dmaID} == 602

函数“at(<index>)”

at 函数允许您根据索引引用集合中的特定元素。
索引0是集合的第一个索引。

<listExpression>.at(<index>)

示例:

此表达式返回列表的第二个推送通知令牌。

@{LobbyBeacon._experience.campaign.message.profile.pushNotificationTokens.at(1).token}

结果为“token_2”。

其他示例

#{ExperiencePlatform.ExperienceEventFieldGroup.experienceevent. all(currentDataPackField._aepgdcdevenablement2.purchase_event.receipt_nbr == "10-337-4016").
_aepgdcdevenablement2.purchase_event.productListItems. all(currentDataPackField.SKU == "AB17 1234 1775 19DT B4DR 8HDK 762").name}
 #{ExperiencePlatform.ExperienceEventFieldGroup.experienceevent.last(
currentDataPackField.eventType == "commerce.productListAdds").productListItems.last(currentDataPackField.priceTotal >= 150).name}
recommendation-more-help
4f4a00c1-77c9-4eee-84df-bbe6206c3ab9