如果在 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 将返回如下错误消息:

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

更新于: 2020年6月20日

235 次查看

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告