mysql - 使用 CASE 条件作为结果值

标签 mysql sql

我想从一组字段中获取最大值,但其中一些字段可能为 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/

相关文章:

java - 如何通过 Hibernate 从数据库中删除一行及其所有引用?

mysql - InnoDB 清除 mariadb 进程列表中的 worker

php - 表单提交时处理 session

sql - 为表中的每一行计算的 Postgres 数学表达式

mysql - 如何在不使用插入查询的情况下在 sql 中插入虚拟行?

php - 如何分解并找到 XYZ 坐标的平均值

asp.net - SQL Server - 存储敏感数据

python - 无法创建 mysql 数据库 python ("can' t 连接到服务器 localhost")

php clone 无法正常工作

mysql - 安全远程 mySQL 连接