如果用於在 UPDATE 語句的 SET 子句中指派新值的子查詢傳回多行,MySQL 會傳回什麼?

王林
發布: 2023-08-27 19:13:02
轉載
852 人瀏覽過

如果用于在 UPDATE 语句的 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 將傳回一條錯誤訊息,如下-< /p>

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
登入後複製

以上是如果用於在 UPDATE 語句的 SET 子句中指派新值的子查詢傳回多行,MySQL 會傳回什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:tutorialspoint.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板