解决mysql错误:Subquery returns more than 1 row问题

吾爱主题 阅读:103 2023-05-06 14:43:00 评论:0

mysql错误:Subquery returns more than 1 row

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

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

报错如下

解决方法

以这个sql语句为例 

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

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

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

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

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

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

?
1 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语句时,其中有个字段是从另一张表里获取

?
1 2 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为一条数据

解决办法

?
1 2 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://blog.csdn.net/LY_Dengle/article/details/78028166

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容