我在SO上看到了这两种情况,但我想知道在合并之前或之后的总和是否有“最佳实践”或优势:
coalesce(sum(value),0) OR sum(coalesce(value),0)只是好奇..。
发布于 2016-05-08 18:11:38
他们不会做同样的事情。如果没有记录,则将COALESCE放入其中不会做任何事情。在这种情况下,将其放在外部也会将结果更改为0。使用哪一个取决于您想要的结果。
发布于 2016-05-08 18:08:46
SQL引擎可能会对此进行优化,但使用
coalesce(sum(value),0) 可能会快一点,因为可以在不需要处理函数的情况下完成求和,并且在最后coalesce被称为one time。
secone版本为每个记录调用coalesce ,如果求和中有null值,则将该值设置为0。
https://stackoverflow.com/questions/37098595
复制相似问题