BigQuery 中的查询命中和自定义维度?

2024-01-10

我正在 BigQuery 中处理 GoogleAnalytics 数据。 我想输出 2 列:特定事件操作(点击)和自定义维度(基于会话)。所有这一切,都使用标准 SQL。我不知道如何正确地做到这一点。文档也没有帮助。请帮我。这就是我正在尝试的:

SELECT
  (SELECT MAX(IF(index=80, value, NULL)) FROM UNNEST(customDimensions)) AS is_app,
  (SELECT hits.eventInfo.eventAction) AS ea
FROM  
  `table-big-query.105229861.ga_sessions_201711*`, UNNEST(hits) hits
WHERE 
  totals.visits = 1
  AND _TABLE_SUFFIX BETWEEN '21' and '21'
  AND EXISTS(SELECT 1 FROM UNNEST(hits) hits
    WHERE hits.eventInfo.eventCategory = 'SomeEventCategory'
  )

尝试为表和子表提供不属于原始表架构的名称。始终告诉您正在引用哪个表 - 交叉连接时,您基本上是在添加新列(此处h.*- 压扁) - 但旧的(hits.*- 嵌套)仍然存在。 我命名为 ga_sessions_*t并用它来引用交叉连接和自定义维度。

另外:您不再需要使用 MAX() 进行自定义维度的旧式 sql 技巧。现在这是一个简单的子查询:)

try:

SELECT
  (SELECT  value FROM t.customDimensions where index=80) AS is_app, -- use h.customDimensions if it is hit-scope
  eventInfo.eventAction AS ea
FROM  
  `projectid.dataset.ga_sessions_201711*` t, t.hits h
WHERE 
  totals.visits = 1
  AND _TABLE_SUFFIX BETWEEN '21' and '21'
  AND h.eventInfo.eventCategory is not null
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

BigQuery 中的查询命中和自定义维度? 的相关文章

随机推荐