Project

General

Profile

Actions

Defect #42203

closed

Time entry details fetch query load issue

Added by Yuvansri Thangavel 9 months ago. Updated 7 months ago.

Status:
Closed
Priority:
Normal
Assignee:
-
Category:
Time tracking
Target version:
-
Start date:
Due date:
% Done:

0%

Estimated time:
Resolution:
Fixed
Affected version:

Description

Time entry details fetch query load issue.

when, i remove where clause query gets executed quickly.(I know the where clause is important to validate the module is enabled for the project).
In JOIN clauses, The query validates issue_tracking module is enabled or not.
again in WHERE Clause, The validation happens for time_tracking module.
In this case, when join exec happens 4496 columns filtered
when exec move to LEFT OUTER JOIN, issue_tracking module validation. 1181 rows get filtered.
Now in where clause another 1181 again.
(4496 * 1181 * 1181) now of rows examined in query is inceased.

SELECT
    `time_entries`.`id` AS t0_r0,
    `time_entries`.`project_id` AS t0_r1,
    `time_entries`.`author_id` AS t0_r2,
    `time_entries`.`user_id` AS t0_r3,
    `time_entries`.`issue_id` AS t0_r4,
    `time_entries`.`hours` AS t0_r5,
    `time_entries`.`comments` AS t0_r6,
    `time_entries`.`activity_id` AS t0_r7,
    `time_entries`.`spent_on` AS t0_r8,
    `time_entries`.`tyear` AS t0_r9,
    `time_entries`.`tmonth` AS t0_r10,
    `time_entries`.`tweek` AS t0_r11,
    `time_entries`.`created_on` AS t0_r12,
    `time_entries`.`updated_on` AS t0_r13,
    `enumerations`.`id` AS t1_r0,
    `enumerations`.`name` AS t1_r1,
    `enumerations`.`position` AS t1_r2,
    `enumerations`.`is_default` AS t1_r3,
    `enumerations`.`type` AS t1_r4,
    `enumerations`.`active` AS t1_r5,
    `enumerations`.`project_id` AS t1_r6,
    `enumerations`.`parent_id` AS t1_r7,
    `enumerations`.`position_name` AS t1_r8
FROM
    `time_entries`
    INNER JOIN `projects` ON `projects`.`id` = `time_entries`.`project_id`
    INNER JOIN `enumerations` ON `enumerations`.`id` = `time_entries`.`activity_id`
    AND `enumerations`.`type` = 'TimeEntryActivity'
    INNER JOIN `users` ON `users`.`id` = `time_entries`.`user_id`
    AND `users`.`type` IN ('User', 'AnonymousUser')
    LEFT OUTER JOIN issues ON issues.id = time_entries.issue_id
    AND (
        projects.status IN (1, 5)
        AND EXISTS (
            SELECT
                1 AS one
            FROM
                enabled_modules em
            WHERE
                em.project_id = projects.id
                AND em.name = 'issue_tracking'
        )
    )
WHERE
    (
        projects.status IN (1, 5)
        AND EXISTS (
            SELECT
                1 AS one
            FROM
                enabled_modules em
            WHERE
                em.project_id = projects.id
                AND em.name = 'time_tracking'
        )
    )
ORDER BY
    time_entries.spent_on DESC,
    time_entries.created_on DESC,
    time_entries.id ASC
LIMIT
    25 OFFSET 0

Mysql : 8.0.37
Ruby : 3.2.4
Raile: 7.2.2


Files

fetch details.png (77.9 KB) fetch details.png time entries fetch details Yuvansri Thangavel, 2025-02-03 04:54
iteration_1.png (125 KB) iteration_1.png it's taken when server receives many requests (peak time) Yuvansri Thangavel, 2025-04-09 07:40

Related issues

Related to Redmine - Defect #40728: Slow loading of global spent time list in MySQLClosedGo MAEDA

Actions
Actions #1

Updated by Go MAEDA 7 months ago

  • Related to Defect #40728: Slow loading of global spent time list in MySQL added
Actions #2

Updated by Go MAEDA 7 months ago

  • Status changed from New to Needs feedback

Could you please check if applying the changes in r23609 will improve performance?

Actions #3

Updated by Yuvansri Thangavel 7 months ago

Yes, I'll check and let you know. Thanks for the update.

Actions #4

Updated by Yuvansri Thangavel 7 months ago

Hi Go MAEDA,
Now i got response with in 5 to 6 seconds avg.

Previously i do some modifications in the code for the quick response. I know it's not a good one
Because, i skip module exist condition validation in time_entry.rb model. Using the below line.

options[:skip_pre_condition] = true; in visible_condition function.

in my case, all my projects must have time entry module. That's why i made this change.
But now i applied your code change. Yep i got quick response now.

Thankyou, so much!

Actions #5

Updated by Go MAEDA 7 months ago

  • Status changed from Needs feedback to Closed
  • Resolution set to Fixed

Thank you for your feedback. This issue was resolved by #40728.

I am closing this issue.

Actions

Also available in: Atom PDF