mysql错误Subquery returns more than 1 row怎么解决
这篇文章主要介绍了mysql错误Subqueryreturnsmorethan1row怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql错误Subqueryreturnsmorethan1row怎么解决文章都会有所收获,下面我们一起来看看吧。
mysql错误:Subquery returns more than 1 rowmysql报错:SQLSTATE[21000]: Cardinality violation: 1242 Subquery returns more than 1 row
错误的意思是指子查询结果多于一行。
报错如下解决方法以这个sql语句为例
select*fromtable1wheretable1.colums=(selectcolumnsfromtable2);
1)如果是写入重复,去掉重复数据。然后写入的时候,可以加逻辑判断(php)或者外键(mysql),防止数据重复写入。
(我实际开发中遇到的就是数据重复写入的情况,在数据库查到有相同的数据两条,这不符原本的原本的业务需求)
2)在子查询条件语句加limit 1,找到一个符合条件的就可以了
select*fromtable1wheretable1.colums=(selectcolumnsfromtable2limit1);
3)在子查询前加any关键字
select*fromtable1wheretable1.colums=any(selectcolumnsfromtable2);错误代码: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语句时,其中有个字段是从另一张表里获取
selectt.id,(selectnumfromt_user_infowhereid=stuNo)asamountfromt_stu_infotleftjoint_user_infot0ont0.id=t.stuNo
查询出num是多条数据,而外层查询结果是要求num为一条数据
解决办法selectt.id,(selectsum(num)fromt_user_infowhereid=stuNo)asamountfromt_stu_infotleftjoint_user_infot0ont0.id=t.stuNo
关于“mysql错误Subqueryreturnsmorethan1row怎么解决”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“mysql错误Subqueryreturnsmorethan1row怎么解决”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注亿速云行业资讯频道。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。