1

我有一个问题,但我似乎还没有找到答案(我已经解决了真正的问题)。

我有一个相当大的查询,可以正常工作.. 3-4 个月,然后在通过添加项目并在应用程序中工作进行了一些更改后,带有 group_concat 的子查询返回了超过 1 行,我认为 group_concat 的重点是 concat 1行中的所有项目?!

简化的查询是这样的:

(SELECT * FROM (SELECT id,
             (other_selects),
    (SELECT GROUP_CONCAT(' ',IF(user_nume IS NOT NULL, (
                    SELECT CONCAT(user_nume,' ',user_prenume)
                    FROM table
                    WHERE u2.user_id = cal_id_user
                    AND i1.cai_id = cal_id_imobil
                    ), (
                        SELECT user_company
                        FROM table
                        WHERE u2.user_id = cal_id_user
                        AND i1.cai_id = cal_id_imobil
                        ) ))
    FROM table2 u2) as locatari,
    ( other selects )   
    .........................
    FROM table3 i1
    ...... JOINS ............
GROUP BY cai_id
ORDER BY cai_id DESC)t" ;)

这个 subqery 返回给我超过 1 行,我不明白如何。

我不得不提到我删除了表名,JOINS 或其他 sintax 错误没有问题。

这个问题的解决方案是添加一个

GROUP BY cal_id_user

在 IF 条件内的两个 SELECTS 中。

有人可以向我解释这个问题是怎么可能的吗?不幸的是,我没有找到此类问题的确切答案。

感谢您的时间。

4

1 回答 1

1

问题是 MySQL 允许您在没有 GROUP BY 子句的情况下使用聚合函数,这太疯狂了。如果没有 GROUP BY,您的查询可以在 MySQL 中运行,但这并不意味着它是正确的。(在 MSSQL 中试试这个,你会看到。)

于 2012-08-23T07:19:49.747 回答