如果用来在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
热门推荐
1 送蛇的祝福语简短
10 六一祝福语简短感动女生
11 九子订婚祝福语简短
12 初升高祝福语家长简短
13 比赛结束花束祝福语简短
14 周末祝福语简短的英语
15 英语简短祝福语给学生
16 爱情祝福语大全 简短实际
17 新年祝福语短句简短搞笑
18 别人过大寿祝福语简短