http://blog.csdn.net/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語句為例。
錯誤的意思是指子查詢結果多於一行。報錯如下:
解決方法:
以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
來源:CSDN
原文:https://blog.csdn.net/ly_dengle/article/details/78028166
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!
(我實際開發中遇到的就是數據重復寫入的情況,在數據庫查到有相同的數據兩條,這不符原本的原本的業務需求)
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
來源:CSDN
原文:https://blog.csdn.net/ly_dengle/article/details/78028166
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!