如果用来在UPDATE语句的SET子句中分配新值的子查询返回多行,MySQL将返回什么?

在这种情况下,MySQL将返回一条错误消息,因为我们知道,如果使用子查询在UPDATE语句的SET子句中分配新值,则它必须为与WHERE子句匹配的更新表中的每一行精确返回一行。

示例

mysql> insert into info(id, remarks) values(5,'average');

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)

正如我们在上面的“信息”表中看到的那样,有两行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
猜你喜欢