聚合函数作为mySQL中的参数

时间:2017-01-08 14:46:09

标签: mysql sql

我正在寻找解决方案,但我找不到答案。是否可以在mySQL中创建将聚合函数作为参数的过程或函数? 例如,如果我调用函数'myFunction(SUM)'它将使用SUM作为聚合函数,如果我调用myFuction(MAX)它将使用MAX。

1 个答案:

答案 0 :(得分:2)

您只能使用动态SQL执行此操作 - 即使用prepareexec语句。

如果你想内联这样做,你可能想要这样的东西:

select (case when myfunction = 'SUM' then sum(x)
             when myfunction = 'MAX' then max(x)
             . . .
        end) as custom_agg

我还应注意,您不能将函数名称作为参数传递。