Subquery returns more than 1 row怎么解决
发布时间:2023-06-06 13:54:18 所属栏目: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错误: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怎么解决”这篇文章的内容就介绍到这里,感谢各位的阅读! (编辑:汽车网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐