表达式语言还为查询集合引入了一组功能。
这些功能在下面进行说明。 在以下示例中,让我们使用包含集合的事件有效负荷:
{
"_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
结果是真的。
示例 2:
在此,我们使用count函数检查集合中是否存在推送通知令牌。
count(@{LobbyBeacon._experience.campaign.message.profile.pushNotificationTokens.all().token}) > 0
结果将是真的。
当all()函数中的过滤条件为空时,过滤器将返回列表中的所有元素。 但是,为了计算集合的元素数,不需要全部函数。
count(@{LobbyBeacon._experience.campaign.message.profile.pushNotificationTokens.token})
表达式结果为3。
示例3:
在此,我们检查过去24小时内是否有个人未收到任何通信。 我们使用两个基于两个事件的表达式来过滤从ExperiencePlatform数据源检索到的体验集合。 特别是,将事件的时间戳与nowWithDelta函数返回的dateTime进行比较。
count(#{ExperiencePlatform.MarltonExperience.experienceevent.all(
currentDataPackField.directMarketing.sends.value > 0 and
currentDataPackField.timestamp > nowWithDelta(-1, "days")).timestamp}) == 0
如果没有与这两个条件匹配的体验事件,则结果将为真。
示例4:
这里,我们要检查个人在过去7天中是否至少启动了一次应用程序,例如触发推送通知,邀请他开始教程。
count(
#{ExperiencePlatform.AnalyticsData.experienceevent.all(
nowWithDelta(-7,"days") <= currentDataPackField.timestamp
and currentDataPackField.application.firstLaunches.value > 0
)._id}) > 0
currentEventField 仅在处理事件集合和currentDataPackField时 可用
处理数据源集合时。 当使用all、first和last处理集合时,我们
逐个循环访问集合的每个元素。 currentEventField 和 currentDataPackField
与所环绕的元素相对应。
函数“first(<condition>
)”和“last(<condition>
)”
first和last函数还在返回满足筛选器的列表的第一个/最后一个元素时启用集合中筛选器的定义。
<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​(currentEventField.application.version == "1.0").token}
结果为“token_2”。
体验事件从Adobe Experience Platform以相反的时间顺序作为集合进行检索,因此:
示例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”。