代码之家  ›  专栏  ›  技术社区  ›  tpdi

Oracle aggregate函数返回组的随机值?

  •  4
  • tpdi  · 技术社区  · 14 年前

    max() 将返回组中的最高值; min()

    Oracle中是否有一个聚合函数从组中返回一个随机值?或者一些技术来达到这个目的?

    foo :

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

    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 回复  |  直到 14 年前
        1
  •  12
  •   josephj1989    14 年前

    你可以尝试以下方法

    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
    /
    

    这个想法是将组中的值按随机顺序排序,然后选择第一个。我可以想出其他方法,但没有一种方法这么有效。

        2
  •  0
  •   mic.sca    10 年前

    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)
    

    这样可以避免使用aggregate函数并指定两次groupby,这在查询非常复杂的情况下很有用/或者您只是浏览数据并手动输入带有冗长且不断变化的groupby列列表的查询。