国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

解決mysql錯誤:Subquery returns more than 1 row問題

瀏覽:83日期:2023-05-05 10:11:53
目錄
  • mysql錯誤:Subquery returns more than 1 row
    • 報錯如下
    • 解決方法
  • 錯誤代碼:1242 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 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
    主站蜘蛛池模板: 睢宁县| 太谷县| 昭苏县| 尖扎县| 永兴县| 平舆县| 西盟| 成安县| 成安县| 鄂州市| 湖口县| 望都县| 平度市| 定州市| 涿鹿县| 昂仁县| 准格尔旗| 盘山县| 青浦区| 革吉县| 南部县| 尼玛县| 藁城市| 威远县| 安阳县| 云龙县| 嘉鱼县| 仙游县| 都安| 宜都市| 郎溪县| 海伦市| 涿州市| 清远市| 韩城市| 盐津县| 象山县| 略阳县| 杨浦区| 西华县| 彭阳县|