gpt4 book ai didi

mysql - 如何提高查询效率

转载 作者:行者123 更新时间:2023-11-29 18:05:10 24 4
gpt4 key购买 nike

我有这样的疑问:

SELECT
*,
(
SELECT COUNT(DISTINCT client_id)
FROM 1097_course_students_tbl
WHERE course_cycl_id=id
AND stts_id <> 8
AND client_id IN(SELECT id FROM 1097_clients_tbl WHERE is_removed=0)
) AS cnt
FROM 1097_course_cycle_tbl
WHERE (course_id IN (SELECT id FROM 1097_courses_tbl WHERE is_removed=2))
ORDER BY start_date DESC

我需要提高效率,因为它需要太长时间

有什么建议吗?

谢谢

最佳答案

尝试以下操作

SELECT cc.*,IFNULL(q.cnt,0) cnt
FROM 1097_course_cycle_tbl cс
JOIN 1097_courses_tbl с ON c.id=cc.course_id AND c.is_removed=2
LEFT JOIN
(
SELECT cs.course_cycl_id,COUNT(DISTINCT cs.client_id) cnt
FROM 1097_course_students_tbl cs
JOIN 1097_clients_tbl c ON cs.client_id=c.id AND c.is_removed=0
WHERE cs.stts_id<>8
GROUP BY cs.course_cycl_id
) q
ON q.course_cycl_id=cс.id
ORDER BY cc.start_date DESC

我认为 1097_courses_tbl1097_clients_tbl 中的 id 是主键。因此我将 IN 替换为 JOIN

我将针对每行执行的 SELECT block 的子查询转换为在 LEFT JOIN 中使用的 GROUP BY 子查询。这里它只会执行一次并返回所有必要的信息。

关于mysql - 如何提高查询效率,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47939684/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com