如果用於是更新語句的 SET 子句中分配新值,子查詢返回多行,MySQL 會返回什麼?


在這種情況下,MySQL 會返回一條錯誤訊息,因為我們知道如果在 UPDATE 語句的 SET 子句中使用子查詢來分配新值,那麼它必須為與 WHERE 子句匹配的更新表中的每行返回一行。

示例

mysql> insert into info(id, remarks) values(5,'average');
Query OK, 1 row affected (0.06 sec)

mysql> select * from info;
+------+-----------+
| id   | remarks   |
+------+-----------+
| 1    | Good      |
| 2    | Good      |
| 3    | Excellent |
| 4    | Average   |
| 5    | Best      |
| 5    | average   |
+------+-----------+
6 rows in set (0.00 sec)

正如我們在上面看到的,“info”表中有兩行 id = 5,因此當我們在子查詢中使用它時,它將返回多行,因此 MySQL 將返回如下錯誤訊息 −

mysql> UPDATE STUDENT SET grade = (SELECT remarks from info WHERE info.id = student.id) WHERE id = 5;
ERROR 1242 (21000): Subquery returns more than 1 row

更新於: 20-06-2020

235 次檢視

開啟你的 職業生涯

透過完成課程獲得認證

開始
廣告
© . All rights reserved.