问题形容:

需要是对某一个字段取最大值和最小值,并且过滤条件不统一,就想到了druid聚合函数反对携带filter子句这一个性,按想法写进去但后果有点奇怪。

问题剖析:

因为须要统计某个字段的最大值和最小值,并且在有Filter条件的状况下,因为Filter条件过滤之后的无后果,所以触发了聚合函数的默认值。
这一点在官网中失去了印证。

解决办法:

count聚合函数联合case子句对空行数据强制赋0。
先用count函数求出过滤条件下的行数。
用case子句判断这个行数是否是0,
如果是0则强制赋0,
如果不是0则认为至多有一条数据,能够应用聚合函数。