作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这样的问题
SELECT * FROM CC
INNER JOIN App (CC.id = App.id)
WHERE CC.counter >1000
AND 0 = IF(CC.key1 = App.key1,
(SELECT COUNT(*)
FROM Service
WHERE App.No = Service.No
)
),
(SELECT COUNT(*)
FROM Service
WHERE App.NoCo = Service.No
AND App.NoCo != ''
)
)
)
如何在 MYSQL 中将条件内部查询转换为 LEFT JOIN?
我正在尝试将此子查询转换为连接子句以获得更好的性能
最佳答案
试试这个:
SELECT * FROM CC
INNER JOIN App (CC.id = App.id)
LEFT JOIN(SELECT s.no,count(*) as cnt_1,sum(s.no <> '') as cnt_2
FROM Service s
GROUP BY s.no) t
ON(0 = CASE WHEN CC.key1 = App.key1 THEN t.cnt_1 ELSE t.cnt_2 END)
WHERE CC.counter >1000
关于mysql - 如何在 MYSQL 中将条件内部查询转换为 LEFT JOIN?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40399249/
我是一名优秀的程序员,十分优秀!