gpt4 book ai didi

MYSQL NTILE 函数从最高百分位数开始

转载 作者:行者123 更新时间:2023-12-04 18:40:33 32 4
gpt4 key购买 nike

我正在使用 MYSQL NTILE 函数,并且在大多数情况下它正在做我需要它做的事情,但是在一种情况下,我需要不同的行为,但我不知道如何去做。这种情况是当我的存储桶多于记录时。

假设我在名为data 的表中的数据如下所示

ID    val
1 15
2 20
3 10

我的问题是当我的存储桶多于记录时,所以假设我运行

select *, NTILE(4) over (order by val) from data

这将导致

ID    val    NTILE
3 10 1
1 15 2
2 20 3

我在表达我的问题时遇到了一些问题,这可能是我努力在 Google 上寻找解决方案的原因,但基本上我的问题是这样的:当我的桶数超过记录(在这个例子中是 4 个桶,但只有 3 个记录),我可以将最高值视为最高百分位数并向后工作,而不是它当前正在做的将最低值视为最低百分位数?本质上是这样的:

ID    val    NTILE
2 20 4
1 15 3
3 10 2

最佳答案

我认为您可以颠倒 NTILE() 中的顺序并像这样在数字上翻转结果:

select *, 5-NTILE(4) over (order by val desc) from data

我预计会发生以下情况(虽然我没有运行过!):

ID    val    NITLE
2 20 4
1 15 3
3 10 2

关于MYSQL NTILE 函数从最高百分位数开始,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59753641/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com