我可以在 MySQL 中将 SUM() 与 IF() 一起使用吗?

mysqlmysqli database

是的,您可以在 MySQL 中将 SUM() 与 IF() 一起使用。让我们首先创建一个演示表:

mysql> create table DemoTable
(
   Value int,
   Value2 int
);
Query OK, 0 rows affected (0.51 sec)

下面是使用 insert 命令在表中插入一些记录的查询:

mysql> insert into DemoTable values(100,400);
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable values(100,400);
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable values(400,100);
Query OK, 1 row affected (0.14 sec)

以下是使用 select 命令显示表中记录的查询:

mysql> select *from DemoTable;

这将产生以下输出

+-------+--------+
| Value | Value2 |
+-------+--------+
|   100 |    400 |
|   100 |    400 |
|   400 |    100 |
+-------+--------+
3 rows in set (0.00 sec)

以下是使用 SUM() 和 IF() 计算上表中有多少个 100 和 400 的查询:

mysql> SELECT SUM(IF(Value=100, 1, 0) + IF(Value2=100, 1, 0)) as Hundred,
SUM(IF(Value=400, 1, 0) + IF(Value2=400, 1, 0)) as FourHundredv
FROM DemoTable;

这将产生以下输出:

+---------+--------------+
| Hundred | FourHundred  |
+---------+--------------+
|       3 |            3 |
+---------+--------------+
1 row in set (0.00 sec)


相关文章