在 MySQL 中为值为 0 或 1 的列设置条件
mysqlmysqli database更新于 2023/11/5 12:10:00
要设置条件,请在 MySQL 中使用 CASE WHEN 语句。让我们首先创建一个表 −
mysql> create table DemoTable -> ( -> Value1 int, -> Value2 int, -> Value3 int, -> Value4 int -> ); Query OK, 0 rows affected (0.98 sec)
使用 insert 命令在表中插入一些记录 −
mysql> insert into DemoTable values(1,0,1,1); Query OK, 1 row affected (0.22 sec) mysql> insert into DemoTable values(1,0,1,0); Query OK, 1 row affected (0.13 sec) mysql> insert into DemoTable values(1,1,1,1); Query OK, 1 row affected (0.20 sec) mysql> insert into DemoTable values(0,0,0,0); Query OK, 1 row affected (0.15 sec)
使用 select 语句显示表中的所有记录 −
mysql> select * from DemoTable;
这将产生以下输出 −
+--------+--------+--------+--------+ | Value1 | Value2 | Value3 | Value4 | +--------+--------+--------+--------+ | 1 | 0 | 1 | 1 | | 1 | 0 | 1 | 0 | | 1 | 1 | 1 | 1 | | 0 | 0 | 0 | 0 | +--------+--------+--------+--------+ 4 rows in set (0.00 sec)
这是在 MySQL 中设置值为 0 或 1 的列的条件的查询 −
mysql> select case when Value1+Value2+Value3+Value4 < 2 then 'NotGood' else 'Good' end as Status from DemoTable;
这将产生以下输出 −
+---------+ | Status | +---------+ | Good | | Good | | Good | | NotGood | +---------+ 4 rows in set (0.00 sec)