使用單一 MySQL 查詢為符合條件的記錄設定不同的 ID


對於條件,在 MySQL 中使用 CASE 語句。我們首先建立一個表 -

mysql> create table DemoTable1545
   -> (
   -> Id int,
   -> FirstName varchar(20)
   -> );
Query OK, 0 rows affected (1.65 sec)

使用 insert 命令向表中插入一些記錄 -

mysql> insert into DemoTable1545 values(1,'John');
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable1545 values(2,'Chris');
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable1545 values(3,'Bob');
Query OK, 1 row affected (0.15 sec)

使用 select 語句從表中顯示所有記錄 -

mysql> select * from DemoTable1545;

這將產生以下輸出 -

+------+-----------+
| Id   | FirstName |
+------+-----------+
|    1 | John      |
|    2 | Chris     |
|    3 | Bob       |
+------+-----------+
3 rows in set (0.00 sec)

以下是使用 CASE 語句設定不同 ID 的查詢 -

mysql> update DemoTable1545
   -> set Id=
   -> case when FirstName like '%John%' then 101
   -> when FirstName like '%Chris%' then 201
   -> when FirstName like '%Bob%' then 501
   -> else Id
   -> end;
Query OK, 3 rows affected (0.18 sec)
Rows matched: 3  Changed: 3 Warnings: 0

讓我們再次檢查表記錄 -

mysql> select * from DemoTable1545;

這將產生以下輸出 -

+------+-----------+
| Id   | FirstName |
+------+-----------+
|  101 | John      |
|  201 | Chris     |
|  501 | Bob       |
+------+-----------+
3 rows in set (0.00 sec)

更新於: 2019 年 12 月 12 日

155 次瀏覽

啟動你的 職業

透過完成該課程獲得認證

開始
廣告
© . All rights reserved.