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

2023年 8月 27日 90.8k 0

如果用于在 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

登录后复制

以上就是如果用于在 UPDATE 语句的 SET 子句中分配新值的子查询返回多行,MySQL 将返回什么?的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论