几天前,以下查询在使用the schema generated by an export from GA的BQ上运行良好
SELECT hits.customDimensions.value
FROM TABLE_DATE_RANGE([88399188.ga_sessions_], TIMESTAMP('20150623'), TIMESTAMP('20150623'))
WHERE hits.customDimensions.index=14
LIMIT 1000现在,我得到以下错误:
Error: Cannot query the cross product of repeated fields customDimensions.index and hits.customDimensions.index.有趣的是,下面的查询运行良好(即没有WHERE子句):
SELECT hits.customDimensions.value
FROM TABLE_DATE_RANGE([88399188.ga_sessions_], TIMESTAMP('20150623'), TIMESTAMP('20150623'))
LIMIT 1000同样,下面的查询也可以正常工作:
SELECT hits.customDimensions.value
FROM [88399188.ga_sessions_20150623]
WHERE hits.customDimensions.index=14
LIMIT 1000请注意,FROM子句是这个查询和失败查询之间的唯一区别;即使它们应该解析为完全相同的查询。请帮帮我!我做错了什么?
发布于 2015-06-26 13:30:48
问题是,两个customDimensions都是重复记录,而命中是重复记录,并且彼此可以相互独立地重复。因此,在过滤hits.customDimensions.index的同时选择hits.customDimensions.value并没有很好地定义含义。例如,如果您希望在non of the hits.customDimensions.index为14时跳过整个记录,则可以使用以下查询:
SELECT hits.customDimensions.value
FROM TABLE_DATE_RANGE(
[88399188.ga_sessions_], TIMESTAMP('20150623'), TIMESTAMP('20150623')
OMIT RECORD IF EVERY(hits.customDimensions.index != 14)
LIMIT 1000发布于 2015-06-30 03:43:17
虽然我还没有得到谷歌的确认,但我不得不假设这是一个临时的bug,已经修复了。
https://stackoverflow.com/questions/31064401
复制相似问题