- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我之前发布了 this related question .此问题的解决方案适用于分析函数 rank()
,但它不适用于 percent_rank()
以正确的方式。为了演示,我有以下虚拟表:
with
table as (
select 'a' as category, 1 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 2 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 3 as num, 5 as num2, 7 as cutoff union all
select 'a' as category, 4 as num, 5 as num2, 7 as cutoff union all
select 'a' as category, 5 as num, 5 as num2, 7 as cutoff union all
select 'a' as category, 6 as num, 5 as num2, 7 as cutoff union all
select 'a' as category, 7 as num, 5 as num2, 7 as cutoff union all
select 'a' as category, 8 as num, 5 as num2, 7 as cutoff union all
select 'a' as category, 9 as num, 5 as num2, 7 as cutoff union all
select 'a' as category, 10 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 11 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 12 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 13 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 14 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 15 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 16 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 17 as num, 5 as num2, 7 as cutoff union all
select 'a' as category, 18 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 19 as num, 15 as num2, 7 as cutoff union all
select 'a' as category, 20 as num, 5 as num2, 7 as cutoff union all
select 'a' as category, 21 as num, 5 as num2, 7 as cutoff
)
num
列需要
percent_rank()
。但是,百分位排名只应考虑 num2 > cutoff
的行。我尝试了以下两种方法来计算百分位数,输出:
select
*,
if(num2 >= cutoff,
percent_rank() over(
partition by category
order by num
), null) as pctile1,
if(num2 >= cutoff,
percent_rank() over(
partition by category
order by if (num2 >= cutoff, num, null) ASC
), null) as pctile2
from table
order by num asc
pctile1
和 pctile2
都不正确。要说明为什么会这样,请查看第 10 行,其中 pctile1 == 0.45
和 pctile2 == 0.60
。但是,在合格值中,这应该是一个较低的百分位数。只有 2 个 qualifying 值低于 num == 10
(即 1 和 2),而有许多大于 10 的值符合条件 (11 - 19)。 num == 10
的正确百分位数,给定 num2
和 cutoff
值,应该接近 30%,因为 10
是 11 个符合条件的值中第三低的值。
请注意,我不应该过滤表以删除我没有percent_rank()
的行,因为我需要保留这些行。
我不确定如何缩小图像大小,但我目前正在尝试这样做。
最佳答案
我只想简单地选择以下选项
#standardSQL
SELECT *,
PERCENT_RANK() OVER(PARTITION BY category ORDER BY num) AS pctile
FROM table WHERE num2 >= cutoff
UNION ALL
SELECT *, NULL
FROM table WHERE num2 < cutoff
-- ORDER BY num
如果应用于您问题中的示例数据 - 输出是
Row category num num2 cutoff pctile
1 a 1 15 7 0.0
2 a 2 15 7 0.1
3 a 3 5 7 null
4 a 4 5 7 null
5 a 5 5 7 null
6 a 6 5 7 null
7 a 7 5 7 null
8 a 8 5 7 null
9 a 9 5 7 null
10 a 10 15 7 0.2
11 a 11 15 7 0.3
12 a 12 15 7 0.4
13 a 13 15 7 0.5
14 a 14 15 7 0.6
15 a 15 15 7 0.7
16 a 16 15 7 0.8
17 a 17 5 7 null
18 a 18 15 7 0.9
19 a 19 15 7 1.0
20 a 20 5 7 null
21 a 21 5 7 null
在我看来,上面的内容很容易阅读,但下面的内容很可能是您想要的
SELECT *,
IF(num2 >= cutoff,
PERCENT_RANK() OVER(PARTITION BY IF(num2 >= cutoff, category, NULL) ORDER BY num),
NULL) AS pctile
FROM table
-- ORDER BY num
显然,结果和上面一样
关于google-bigquery - BigQuery 中的 percent_rank() 有条件地仅包含某些行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62630152/
我有一个包含数据的表,其中在 A 列中我有一组重复的数据(一个接一个)。 我只想根据 A 列中的值(没有其他条件)选择每个组的第一行。请注意,我还希望为提到的新发现的行选择所有相应的列(我不想排除它们
我有一个包含 340GB 数据的表,但我们只使用了最后一周的数据。因此,为了最小化将这些数据移动到分区表或分片表的成本计划。 我对分片表和分区做了一些实验。我创建了分区表并加载了两天的数据(两个分区)
我想安排将数据从 GCS 存储桶加载到 BigQuery 表。如果我使用 bigquery-transfer 与调度及时的 bigquery-loads 的核心区别是什么? 最佳答案 它们是相同的。
我想安排将数据从 GCS 存储桶加载到 BigQuery 表。如果我使用 bigquery-transfer 与调度及时的 bigquery-loads 的核心区别是什么? 最佳答案 它们是相同的。
我想编写一个 BigQuery 命令行命令来检索 BigQuery 表的最后修改时间。我怎样才能做到这一点? 仅当 BigQuery 表的最后修改日期时间大于某个日期时间时,我才会使用它。 最佳答案
我似乎无法将任何数据从 Socrata 上传到 BigQuery。我收到“加载操作中的 BigQuery 错误:无法连接 BigQuery 服务器。”最初我得到的是 0 错误错误的限制。现在我已将 C
我正在尝试弄清楚是否可以从大查询中导出 hyperloglog 草图并在外部合并它们以进行基数估计。是否有可用的开源库可以轻松解析大型查询草图? 如果不是,是否有任何关于 biq 查询的 hyperl
这是我用作https://cloud.google.com/bigquery/docs/managing-tables#bigquery-copy-table-python的引用的代码: source
构建管道时,源是 BigQueryIO.Read,您会得到一组 TableRow 对象以供使用。 我基本上想对那些 TableRow 对象进行一些小的更改,然后使用 BigQueryIO.Write
BigQuery API Client Libraries 之间有什么区别?和 BigQuery Storage API Client Libraries ? 在 BigQuery Storage R
据我所知,将数据流式传输到 BigQuery 会导致重复行,正如这里提到的 https://cloud.google.com/bigquery/streaming-data-into-bigquery
我在 BigQuery Jobs API 中注意到复制任务: https://developers.google.com/bigquery/docs/reference/v2/jobs#resourc
https://cloud.google.com/bigquery/docs/reference/datatransfer/rest/ 我正在寻找“bigquery 数据传输服务”的 php 客户端库
我正在从 GCS 中的 CSV 文件到 BQ 执行一些 ETL,一切正常,除了日期。我的表中的字段名称是 TEST_TIME,类型是 DATE,所以在 TableRow 中我尝试传递一个 java.u
我已经阅读了 BigQuery 连接器的文档(https://support.google.com/360suite/datastudio/answer/6370296?hl=en)。 我想将自定义查
当两个不同的billing account下有两个project,并且有跨两个project的授权view时,view的查询费用由哪个billing account来计费? 场景:项目 A 包含使用项
所以我有一张购买表: 用户编号 购买时间 数量 我有一张网站上的用户事件表: 用户编号 位置 浏览时间 如何在不超过 purchase_time 的情况下将 purchases 表与 activiti
我有一个 unix 时间戳列,在我的 csv 文件中以毫秒表示。现在,当我将这些数据插入到我的 bigQuery 表中并查询它时,我得到了这个错误 bigQuery not supporting mi
我目前正在将 BigQuery 表提取到 Google Cloud Storage 中的分片 .csv 中——是否有任何方法可以对提取的行进行洗牌/随机化? GCS .csv 将用作 GCMLE 模型
我需要从数据流更新和删除 BigQuery 中的记录。数据来自 Pubsub,并带有标识操作插入、更新、删除 (I、U、D) 的标志。插入不是问题。 有更新和删除的建议吗? 最佳答案 Dataflow
我是一名优秀的程序员,十分优秀!