Oracle聚合函数为组返回一个随机值?
发布时间:2021-04-03 14:53:51 所属栏目:站长百科 来源:网络整理
导读:标准SQL聚合函数max()将返回组中的最高值; min()将返回最低值. Oracle中是否有一个聚合函数来从组中返回一个随机值?还是一些技术来实现这一目标? 例如,给出表foo: group_id value1 11 51 92 22 42 8 SQL查询 select group_id,max(value),min(value),some_
标准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),some_aggregate_random_func(value) 1 9 1 1 2 8 2 4 很明显,最后一列是该组中的任何随机值. 解决方法您可以尝试以下内容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 / 我们的想法是按随机顺序对组内的值进行排序并选择第一个.我可以想到其他方法,但没有一个方面有效. (编辑:威海站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |