如何在一个查询中执行这两个查询,以便它显示具有2个以上值的eid并显示其eid?
select eid, count(Edited_by.eid)
from Edited_by
group by eid;
select Editor.eid
from Editor
where ( select count(*)
from Edited_by
where Edited_by.eid=Editor.eid ) > 2;
答案 0 :(得分:0)
<强> 更新 强>
HAVING
子句中的谓词可以对聚合表达式进行操作。我想你可能正在寻找这样的东西:
SELECT t.eid
, COUNT(t.eid) AS cnt
FROM Edited_by t
GROUP BY t.eid
HAVING COUNT(t.eid) > 2
糟糕。我完全错过了两个查询引用了两个不同的表。
要同时引用Editor
表,您可以使用上面的查询作为内联视图。
SELECT c.eid AS edited_by_eid
, c.cnt AS cnt
, IF(c.cnt>2,e.Eid,NULL) AS editor_eid
FROM Editor e
JOIN ( SELECT t.eid
, COUNT(t.eid) AS cnt
FROM Edited_by t
GROUP BY t.eid
) c
ON c.eid = e.Eid
<强>后续强>
问:&#34;我希望通过运行一个来获得两个查询的结果。&#34;
答:我不明白你想要达到的目标。
要返回两个单独的结果集,您需要运行两个单独的语句。 MySQL可以从存储过程返回多个结果集,例如,过程可以执行两个查询。客户端可以处理两个结果集(如果在客户端接口库中支持和启用了这些结果集)。这将是一个&#34;单个语句&#34; (CALL my_procedure;
)。
如果要连接两个单独查询的结果,可以使用UNION ALL集合运算符。通常,我会返回一个鉴别器列来区分哪个查询返回哪些行。为此,每列的列数和数据类型必须在两个查询之间匹配。
在您给出的示例中,来自Editor表的查询需要返回一个虚拟整数类型列,以便连接两个结果。
SELECT t.eid
, COUNT(Edited_by.eid) AS cnt
FROM Edited_by t
GROUP BY t.eid
UNION ALL
SELECT e.eid
, 0 AS cnt
FROM Editor e
WHERE ( SELECT COUNT(*)
FROM Edited_by c
WHERE c.eid=e.eid
) > 2