我正在寻找解决方案,但我找不到答案。是否可以在mySQL中创建将聚合函数作为参数的过程或函数? 例如,如果我调用函数'myFunction(SUM)'它将使用SUM作为聚合函数,如果我调用myFuction(MAX)它将使用MAX。
答案 0 :(得分:2)
您只能使用动态SQL执行此操作 - 即使用prepare
和exec
语句。
如果你想内联这样做,你可能想要这样的东西:
select (case when myfunction = 'SUM' then sum(x)
when myfunction = 'MAX' then max(x)
. . .
end) as custom_agg
我还应注意,您不能将函数名称作为参数传递。