如果用于是更新语句的 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
广告