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

Oracle聚合函数为组返回一个随机值?,第1张

概述标准SQL聚合函数max()将返回组中的最高值; min()将返回最低值. Oracle中是否有一个聚合函数来从组中返回一个随机值?还是一些技术来实现这一目标? 例如,给出表foo: group_id value1 11 51 92 22 42 8 SQL查询 select group_id, max( 标准sql聚合函数max()将返回组中的最高值; min()将返回最低值.

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

例如,给出表foo:

group_ID value1        11        51        92        22        42        8

SQL查询

select group_ID,max(value),min(value),some_aggregate_random_func(value)from foogroup by group_ID;

可能产生:

group_ID  max(value),some_aggregate_random_func(value)1        9            1           12        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_salfrom emp)group by deptno/

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

总结

以上是内存溢出为你收集整理的Oracle聚合函数为组返回一个随机值?全部内容,希望文章能够帮你解决Oracle聚合函数为组返回一个随机值?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1166834.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存