我想从一组字段中获取最大值,但其中一些字段可能为 NULL,因此我不能按原样使用 GREATEST,并且我必须将 NULL 值转换为任意值(在本例中为 -1) 。但是在结果中,如果所有字段都为 NULL,我仍然必须获得 NULL 值。
SELECT
CASE WHEN GREATEST(IFNULL(f1, -1), IFNULL(f2, -1)) = -1 THEN
NULL
ELSE
GREATEST(IFNULL(f1, -1), IFNULL(f2, -1))
END
我的问题是,我计算了最大值的两倍,所以我想知道是否有一种方法来“存储”该值,以便 mySQL 不必计算两次。
或者是否有更好/更合适的方法来做我想做的事。
谢谢。
最佳答案
您可以使用NULLIF
功能:
NULLIF(GREATEST(IFNULL(f1, -1), IFNULL(f2, -1)), -1)
它将返回NULL
如果它们相等,则为第一个参数的值,否则为第一个参数的值。
引用文献:
关于mysql - 使用 CASE 条件作为结果值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26648433/