Oracle聚合函数为组返回一个随机值?

时间:2010-06-18 01:32:58

标签: oracle plsql random aggregate

标准SQL聚合函数max()将返回组中的最高值; min()将返回最低值。

Oracle中是否有聚合函数从组中返回随机值?还是一些技术来实现这个目标?

,如表foo所示:

group_id value
1        1
1        5
1        9
2        2
2        4
2        8

SQL查询

select group_id, max(value), min(value), some_aggregate_random_func(value)
from foo
group by group_id;

可能会产生:

group_id  max(value), min(value), some_aggregate_random_func(value)
1        9            1           1
2        8            2           4

显然,最后一列是该组中的任意随机值

2 个答案:

答案 0 :(得分:10)

您可以尝试以下内容

select deptno,max(sal),min(sal),max(rand_sal) 
from(
select deptno,sal,first_value(sal) 
     over(partition by deptno order by dbms_random.value) rand_sal
from emp)
group by deptno
/

我们的想法是按随机顺序对组内的值进行排序,然后选择第一个。我可以想到其他方法,但没有一个方法有效。

答案 1 :(得分:0)

您可以在要从中提取随机元素的列前置一个随机字符串,然后选择该列的min()元素并取出前置字符串。

select group_id, max(value), min(value), substr(min(random_value),11)
from (select dbms_random.string('A', 10)||value random_value,foo.* from foo)

通过这种方式,您可以避免使用聚合函数并指定两次分组,这可能在您的查询非常复杂的情况下非常有用,或者您只是在探索数据并且正在进行冗长的手动查询按列更改分组列表。