mysql子查询重复利用_mysql – 如何在查询中多次使用子查询的结果

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

SELECT COUNT(*),(SELECT hash FROM sets WHERE ID=1)

FROM sets

WHERE hash=(SELECT hash FROM sets WHERE ID=1)

and XD=2;

有没有办法避免子查询的双重执行(SELECT hash FROM设置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;

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

+----------+------+

| count(*) | HASH |

+----------+------+

| 0 | NULL |

+----------+------+

而不是像(我需要的):

+----------+------+

| count(*) | HASH |

+----------+------+

| 0 | 8115e|

+----------+------+

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

//编辑:

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

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值