mysql错误Subquery returns more than 1 row怎么解决

45次阅读
没有评论

共计 1519 个字符,预计需要花费 4 分钟才能阅读完成。

数据库    
MySQL 数据库    
mysql 错误 Subquery returns more than 1 row 怎么解决

这篇文章主要介绍了 mysql 错误 Subquery returns more than 1 row 怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇 mysql 错误 Subquery returns more than 1 row 怎么解决文章都会有所收获,下面我们一起来看看吧。

mysql 错误:Subquery returns more than 1 row

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

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

报错如下

mysql 错误 Subquery returns more than 1 row 怎么解决

解决方法

以这个 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

关于“mysql 错误 Subquery returns more than 1 row 怎么解决”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“mysql 错误 Subquery returns more than 1 row 怎么解决”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注丸趣 TV 行业资讯频道。

向 AI 问一下细节

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2024-04-09发表,共计1519字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)