[英]How can I make this query run faster
我正在我的網站上運行此查詢,以便根據特定條件查找待辦事項列表。 但是它運行太慢,可能可以用其他方式編寫它。
SELECT * FROM lesson WHERE
id IN
(SELECT `lesson_id` FROM `localization_logging`
WHERE `language_id` = 2 AND `action_id` = 1)
AND `id` NOT IN
(SELECT `lesson_id` FROM `localization_logging`
WHERE `language_id` = 2 AND `part_id` = 1 AND `action_id` = 6)
該查詢所做的是,它在課程表中查找所有課程列表名稱,然后檢查特定任務是否完成。 如果任務是在一個任務中完成的,則在下一個任務中顯示。 在這種情況下,將執行操作1,但不執行操作6。
我希望我能解釋得足夠好。 在我的本地計算機上,查詢需要1.8秒,有時我必須將多個列表彼此相鄰打印,然后它需要使用1.8倍的列表,這使得頁面加載非常慢。
這樣的標記ID已完成:
SELECT l.*, SUM(ll.action_id=6) completed FROM lesson l
INNER JOIN localization_logging ll ON ll.lesson_id = l.id
WHERE ll.language_id = 2 AND
(
ll.action_id = 1
OR
ll.action_id = 6 AND ll.part_id == 1
)
GROUP BY l.id
現在,我們可以將其包裝為:
SELECT t.* FROM (...) t WHERE t.completed = 0
通常,您可以使用INNER/LEFT JOIN
獲得更快的查詢來過濾行,但是您需要對其進行測試。
SELECT lesson.* FROM lesson
INNER JOIN localization_logging task1
ON lesson.id = task1.lesson_id
LEFT JOIN localization_logging task2
ON lesson.id = task2.lesson_id
AND task2.language_id = 2
AND task2.part_id = 1
AND task2.action_id = 6
WHERE task1.language_id = 2
AND task1.action_id = 1
AND task2.lesson_id IS NULL
第二個表在多個條件下被聯接,但是必須在ON
子句中列出它們,因為僅需要將結果“強制聯接”為空的結果(空聯接意味着無論什么情況都保留)。
順便說一句。 如果task1
條件不將結果限制為一行,則您將從lesson
獲得多行-然后是GROUP BY lesson.id
。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.