如何在查询中多次使用子查询的结果

The*_*ndr 5 mysql sql subquery

MySQL查询需要不同位置的子查询结果,如下所示:

SELECT COUNT(*),(SELECT hash FROM sets WHERE ID=1) 
     FROM sets 
     WHERE hash=(SELECT hash FROM sets WHERE ID=1) 
           and XD=2;
Run Code Online (Sandbox Code Playgroud)

有没有办法避免子查询的双重执行(SELECT hash FROM sets WHERE ID=1)?子查询的结果始终返回有效的哈希值.重要的是主查询的结果还包括HASH.

首先我尝试了JOIN这样的:

SELECT COUNT(*), m.hash FROM sets s INNER JOIN sets AS m
     WHERE s.hash=m.hash AND id=1 AND xd=2;
Run Code Online (Sandbox Code Playgroud)

如果XD = 2与行不匹配,则结果为:

+----------+------+
| count(*) | HASH |
+----------+------+
|        0 | NULL | 
+----------+------+
Run Code Online (Sandbox Code Playgroud)

而不是像(我需要的):

+----------+------+
| count(*) | HASH |
+----------+------+
|        0 | 8115e| 
+----------+------+
Run Code Online (Sandbox Code Playgroud)

有任何想法吗?请告诉我!预先感谢您的任何帮助.

//编辑:最后该查询只需计算表中具有相同散列值的所有条目,如ID = 1且XD = 2的条目.如果没有行匹配(如果XD设置为其他数字,则发生此情况),因此返回0并简单地哈希值.

Qua*_*noi 2

SELECT  SUM(xd = 2), hash
FROM    sets
WHERE   id = 1
Run Code Online (Sandbox Code Playgroud)

如果id是 a PRIMARY KEY(我认为这是因为您正在对其使用单记录查询),那么您可以删除SUM

SELECT  xd = 2 AS cnt, hash
FROM    sets
WHERE   id = 1
Run Code Online (Sandbox Code Playgroud)

更新:

抱歉,你的任务搞错了。

尝试这个:

SELECT  si.hash, COUNT(so.hash)
FROM    sets si
LEFT JOIN
        sets so
ON      so.hash = si.hash
        AND so.xd = 2
WHERE   si.id = 1
Run Code Online (Sandbox Code Playgroud)

  • @TheBndr:欢迎!现在请将我的答案标记为已接受,这样我将获得额外的“15”点声誉,这将使我的自我膨胀得更多一些。 (5认同)