如何在 MySQL 中為某個單獨欄位中的鍵對映值?


在 MySQL 中,可以使用 CASE 語句將鍵對映到 select 查詢中的單個欄位的值。語法如下:

SELECT yourColumnName1,yourColumnName2,yourColumnName3,.........N
(
   CASE WHEN yourColumnName = 1 THEN 'ENABLED'
   ELSE 'DISABLED'
   END
) AS anyVariableName
FROM yourTableName;

也可以使用 IF() 函式達到相同目的。語法如下:

SELECT yourColumnName1,yourColumnName2,yourColumnName3,.........N
,IF(yourColumnName,'ENABLED','DISABLED') as anyVariableName FROM yourTableName;

為了理解上面的語法,讓我們建立一個表。用於建立表的查詢如下:

mysql> create table MapKeys
   -> (
   -> Id int NOT NULL AUTO_INCREMENT,
   -> Name varchar(20),
   -> isActive boolean,
   -> PRIMARY KEY(Id)
   -> );
Query OK, 0 rows affected (0.65 sec)

使用插入命令在表中插入一些記錄。查詢如下:

mysql> insert into MapKeys(Name,isActive) values('Larry',true);
Query OK, 1 row affected (0.13 sec)

mysql> insert into MapKeys(Name,isActive) values('David',false);
Query OK, 1 row affected (0.16 sec)

mysql> insert into MapKeys(Name,isActive) values('Mike',true);
Query OK, 1 row affected (0.14 sec)

mysql> insert into MapKeys(Name,isActive) values('Carol',false);
Query OK, 1 row affected (0.17 sec)

mysql> insert into MapKeys(Name,isActive) values('Sam',false);
Query OK, 1 row affected (0.15 sec)

mysql> insert into MapKeys(Name,isActive) values('Bob',true);
Query OK, 1 row affected (0.19 sec)

使用 select 語句顯示錶中的所有記錄。查詢如下:

mysql> select *from MapKeys;

輸出如下:

+----+-------+----------+
| Id | Name  | isActive |
+----+-------+----------+
|  1 | Larry |        1 |
|  2 | David |        0 |
|  3 | Mike  |        1 |
|  4 | Carol |        0 |
|  5 | Sam   |        0 |
|  6 | Bob   |        1 |
+----+-------+----------+
6 rows in set (0.00 sec)

現在,讓我們使用 case 語句對映鍵。查詢如下:

mysql> select Id,Name,
   -> (
   -> CASE WHEN isActive = 1 THEN 'ENABLED'
   -> ELSE 'DISABLED'
   -> END
   -> ) AS Status
   -> from MapKeys;

輸出如下:

+----+-------+----------+
| Id | Name  | Status   |
+----+-------+----------+
|  1 | Larry | ENABLED  |
|  2 | David | DISABLED |
|  3 | Mike  | ENABLED  |
|  4 | Carol | DISABLED |
| 5  | Sam   | DISABLED |
| 6  | Bob   | ENABLED  |
+----+-------+----------+
6 rows in set (0.00 sec)

藉助 IF() 函式,你可以實現同樣的目的:

mysql> select Id,Name,if(isActive,'ENABLED','DISABLED') as Status from MapKeys;

輸出如下:

+----+-------+----------+
| Id | Name  | Status   |
+----+-------+----------+
| 1 | Larry | ENABLED   |
| 2 | David | DISABLED |
| 3 | Mike   | ENABLED |
| 4 | Carol | DISABLED |
| 5 | Sam   | DISABLED |
| 6 | Bob   | ENABLED  |
+----+-------+----------+
6 rows in set (0.00 sec)

更新日期:30-6-2020

2K+ 瀏覽

踏上您的 職業生涯

透過完成課程獲得認證

開始學習
廣告
© . All rights reserved.