簡體   English   中英

如何使此查詢運行更快

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM