Sql 如何查找column1值超过整个数据集平均column1值两倍的所有数据行?
我试图用下面的代码查找数据集中column1值超过平均column1值两倍的所有数据行,但它似乎不是正确的数据。 代码如下:Sql 如何查找column1值超过整个数据集平均column1值两倍的所有数据行?,sql,select,google-bigquery,average,aggregate-functions,Sql,Select,Google Bigquery,Average,Aggregate Functions,我试图用下面的代码查找数据集中column1值超过平均column1值两倍的所有数据行,但它似乎不是正确的数据。 代码如下: select *,column1 over() from databasetest.Table1 where column1 > (select 2*avg(column1) from databasetest.Table1) 这是示例输出 如您所见,column1值仍然小于整个数据集平均column1值的两倍。我认为这应该检索整个数据集中column1平均值两
select *,column1 over() from databasetest.Table1
where column1 > (select 2*avg(column1) from databasetest.Table1)
这是示例输出
如您所见,column1值仍然小于整个数据集平均column1值的两倍。我认为这应该检索整个数据集中column1平均值两倍以上的列。
我是做错了什么还是误解了什么?
如果我理解正确,您可以使用窗口功能,我们将不胜感激
select *
from (select t1.*, avg(column1) over () as avg_column1
from databasetest.Table1 t1
) t1
where t1.column1 > 2 * avg_column1;
谢谢你的宝贵时间,你知道我的代码为什么不起作用吗?@lili。您的代码在语法上不正确。根据问题指南,请不要发布代码、数据、错误消息等的图像-复制或在问题中键入文本。请保留图像用于图表或演示渲染错误,这些内容无法通过文本准确描述。