我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

解决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

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

报错如下

解决方法

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

目录mysql错误:Subquery returns more than 1 row报错如下解决方法错误代码:1242 Subquery returns more than 1 row错误描述错误原因解决办法总结mysql错误:Subque
2023-05-05

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

这篇文章主要介绍了解决mysql错误:Subquery returns more than 1 row问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-05-18

如何解决php mysql query 错误问题

php mysql query错误的解决办法:1、为php连接的用户添加指定的操作权;2、改正所有的语法错误;3、检查mysql服务器是否有问题并修改即可。
2019-05-18

mysql连接错误2013的问题及解决

这篇文章主要介绍了mysql连接错误2013的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-05-20

解决Python 出现File “<stdin>“, line 1非语法错误的问题

这篇文章主要介绍了Python 出现File “<stdin>“, line 1非语法错误的解决办法,本文给大家讲解的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-03-14

解决Navicat for MySQL 连接 MySQL 报2005错误的问题

上篇文章给大家介绍过解决Navicat for Mysql连接报错1251的问题(连接失败),今天介绍Navicat for MySQL 连接 MySQL 报2005错误的问题。 关于Navicat for MySQL 连接 MySQL 报
2022-05-19

编程热搜

目录