• ADADADADAD

    mysql错误Subquery returns more than 1 row怎么解决[ mysql数据库 ]

    mysql数据库 时间:2024-11-25 13:35:40

    作者:文/会员上传

    简介:

    mysql错误:Subquery returns more than 1 rowmysql报错:SQLSTATE[21000]: Cardinality violation: 1242 Subquery returns more than 1 row错误的意思是指子查询结果多于一行

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

        mysql错误:Subquery returns more than 1 row

        mysql报错:SQLSTATE[21000]: Cardinality violation: 1242 Subquery returns more than 1 row

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

        报错如下解决方法

        以这个sql语句为例

        select*fromtable1wheretable1.colums=(selectcolumnsfromtable2);

        1)如果是写入重复,去掉重复数据。然后写入的时候,可以加逻辑判断(php)或者外键(mysql),防止数据重复写入。

        (我实际开发中遇到的就是数据重复写入的情况,在数据库查到有相同的数据两条,这不符原本的原本的业务需求)

        2)在子查询条件语句加limit 1,找到一个符合条件的就可以了

        select*fromtable1wheretable1.colums=(selectcolumnsfromtable2limit1);

        3)在子查询前加any关键字

        select*fromtable1wheretable1.colums=any(selectcolumnsfromtable2);
        错误代码: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语句时,其中有个字段是从另一张表里获取

        selectt.id,(selectnumfromt_user_infowhereid=stuNo)asamountfromt_stu_infotleftjoint_user_infot0ont0.id=t.stuNo

        查询出num是多条数据,而外层查询结果是要求num为一条数据

        解决办法
        selectt.id,(selectsum(num)fromt_user_infowhereid=stuNo)asamountfromt_stu_infotleftjoint_user_infot0ont0.id=t.stuNo
    mysql错误Subquery returns more than 1 row怎么解决.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: mysql