将子查询中的多行插入到 MySQL 表中
要将子查询中的多行插入到 MySQL 表中,至关重要的是要确保子查询仅返回一行。在提供的代码片段中,插入查询:
INSERT INTO Results (People, names) VALUES ( (SELECT d.id FROM Names f JOIN People d ON d.id = f.id), ("Henry"), );
尝试将两个值插入到“人员”和“名称”列中。但是,第一个括号内的子查询返回 d.id 的多行。这会导致错误“子查询返回超过 1 行。”
使用组合静态字符串的解决方案
插入静态字符串“Henry”,同时保留以下结果子查询,按如下方式修改查询:
INSERT INTO Results (People, names) SELECT d.id, 'Henry' FROM Names f JOIN People d ON d.id = f.id
通过使用逗号将静态字符串“Henry”与子查询组合,查询将每行的名称列的值显式设置为“Henry”由子查询返回。这可确保查询将子查询的结果与指定值一起插入表中,而不会遇到错误。
以上是当子查询返回多于一行时,如何将子查询中的多行插入到 MySQL 表中?的详细内容。更多信息请关注PHP中文网其他相关文章!