我正在使用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'
)
答案 0 :(得分:6)
尝试为您的表和子表提供不属于原始表架构的名称。总是告诉您所指的是哪个表 - 在交叉加入时,您基本上添加了新列(此处为h.*
- 展平) - 但旧的(hits.*
- 嵌套的)仍然存在存在。
我将ga_sessions_ * t
命名为并使用它来引用交叉连接以及customDimension。
另外:您不再需要使用MAX()来获取customDimensions的遗留sql技巧。它现在是一个简单的子查询:)
尝试:
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