商城首页欢迎来到中国正版软件门户

您的位置:首页 >如何解决 MySQL 错误 "Subquery returns more than 1 row"?

如何解决 MySQL 错误 "Subquery returns more than 1 row"?

  发布于2023-05-07 阅读(0)

扫一扫,手机访问

    mysql错误:Subquery returns more than 1 row

    mysql报错:SQLSTATE[21000]: Cardinality violation: 1242 Subquery returns more than 1 row

    错误的意思是指子查询结果多于一行。

    报错如下

    如何解决 MySQL 错误

    解决方法

    以这个sql语句为例 

    select * from table1 where table1.colums=(select columns from table2);

    1)如果是写入重复,去掉重复数据。然后写入的时候,可以加逻辑判断(php)或者外键(mysql),防止数据重复写入。

    (我实际开发中遇到的就是数据重复写入的情况,在数据库查到有相同的数据两条,这不符原本的原本的业务需求)

    2)在子查询条件语句加limit 1,找到一个符合条件的就可以了

    select * from table1 where table1.colums=(select columns from table2 limit 1);

    3)在子查询前加any关键字

    select * from table1 where table1.colums=any(select columns from table2);

    错误代码:1242 Subquery returns more than 1 row

    错误描述

    1 queries executed, 0 success, 1 errors, 0 warnings

    查询:SELECT t.id, DATE_FORMAT( t.statisTime, '%Y-%m-%d %H:%i:%s' ) statisTime, (SELECT `id` FROM t_truck_info WHERE id = t.plateId...

    错误代码: 1242Subquery returns more than 1 row

    执行耗时   : 0.009 sec传送时间   : 0.002 sec总耗时      : 0.012 sec

    错误原因

    在编写查询SQL语句时,其中有个字段是从另一张表里获取

    select t.id,(select num from t_user_info where id = stuNo) as amount from t_stu_info t left join t_user_info t0
    on t0.id = t.stuNo

    查询出num是多条数据,而外层查询结果是要求num为一条数据

    解决办法

    select t.id,(select sum(num) from t_user_info where id = stuNo) as amount from t_stu_info t left join t_user_info t0
    on t0.id = t.stuNo
    本文转载于:https://www.yisu.com/zixun/804513.html 如有侵犯,请联系zhengruancom@outlook.com删除。
    免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

    热门关注