在這種情況下,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中文網其他相關文章!