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

标签 sql google-analytics google-bigquery bigquery-standard-sql

我正在使用 BigQuery 中的 GoogleAnalytics 数据。 我想输出 2 列:特定事件操作(点击)和自定义维度(基于 session )。所有这一切,使用标准 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 并用它来引用交叉连接和 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

关于sql - BigQuery 中的查询命中和自定义维度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48117541/

相关文章:

mysql查询在列表中最后一个特定标记之后获取行

php - 如何查询多个表并使用附加

sql - T-SQL 存储过程中的空比较

sql - 在 Google Big Query 中连接重复记录

android - Firebase Analytics - 在 device_Info 或 geo_info 中添加自定义键

angular - gtag 自定义维度未被 Google Analytics(分析)拾取

google-analytics - 分析多领域目标跟踪

google-bigquery - 如何通过 HTTP API 获取 BigQuery 查询的元数据

google-bigquery - 选择大数据仓库

sql - 在 BigQuery 中优化查询