解决"Subquery returns more than 1 row"sql查询错误

博客提及一个SQL错误[Err] 1242,即子查询返回了多行数据,并给出示例语句“select * from table1 where table1.colums=(select columns from table2)”,重点在于探讨该问题的解决方法。

http://blog.youkuaiyun.com/c517984604/article/details/7052186 [Err] 1242 - Subquery returns more than 1 row   --表示子查询返回了多行数据

例如:

select * from table1 where table1.colums=(select columns from table2)

解决方法

1,select * from table1 where column=any(select columns  from table2)

2,select * from table1 where column in(select columns  from table2);

3,select * from table1 a where exists 
(select columns from tableb2 b
where b.column=a.column
);
 
 
 ========================================================================
mysql报错:SQLSTATE[21000]: Cardinality violation: 1242 Subquery returns more than 1 row
错误的意思是指子查询结果多于一行。报错如下:
解决方法:
以select * from table1 where table1.colums=(select columns from table2);这个sql语句为例。
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);
---------------------
作者:ly_dengle
来源:优快云
原文:https://blog.youkuaiyun.com/ly_dengle/article/details/78028166
版权声明:本文为博主原创文章,转载请附上博文链接!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值