mysql错误:subquery returns more than 1 rowmysql报错:sqlstate[21000]: cardinality violation: 1242 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 t0on 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 t0on t0.id = t.stuno
以上就是mysql错误subquery returns more than 1 row怎么解决的详细内容。
